VB.NET2002を使用しています。
VBよりEXCELマクロを実行できるとこまでは出来たのですが、
excel.Application.Run("Module1!test")
VBで処理した値をExcelに渡すことはできないのでしょうか?
Run("マクロ名",引数1,引数2,・・・)のように宣言すれば良さそうなのですが、 型のエラーが出てしまいます。
VB上の吹き出しには「As Object」とあるのですが、実際には文字列(string)や数字(long)です。
そのままRun("test",moji,suuji)のようには無理でしょうか。
ちなみにExcelの受け側ですが、
test(byval moji as string,byval num as integer)
のようにすれば…と思っていたのですが。
ご存知の方がいらっしゃいましたら教えてください。
お願いいたします。
No.3ベストアンサー
- 回答日時:
こんにちは。
>excel.Application.Run("Module1!test")
excel.Application.Run("Book1.xls!test")
これは、直していただくとして、
Dim moji As String
Dim num As Int32 '型は違ってはいますが……
excel.Run("Book1.xls!test", moji, num)
で、特に問題ないと思いますが、逆なら、Excel側から型のエラーが出てしまうでしょうね。
たとえば、以下のように、Excel側の文字と数値の引数が、逆になっていると間違えますね。
Book1.xls!Test
Function test(ByVal moji As String, ByVal num As Integer)
test = String$(num, moji)
End Function
No.4
- 回答日時:
ANo.1 の者です。
VB.NETというのを見逃してました。
VB.NETとVBAではデータ型が異なるのですが、そこはOKでしょうか?
VBAとVB.NETのデータ型の対応は
VBA --- VB.NET
--------------------
Integer --- Short
Long --- Integer
Single --- Single
Double --- Double
String --- String
No.2
- 回答日時:
>VBよりEXCELマクロを実行できるとこまでは出来たのですが、
できている部分があるのであれば、次回からはできている部分も載せましょう。
もしかして↓この部分?
>excel.Application.Run("Module1!test")
Runの第一引数は
×モジュール!関数名
ではなく
○ブック名!関数名
です。
↓以下のように行ったらできます。
※エクセル
Public Function test(ByVal moji As String, ByVal num As Integer) As String
test = "mojiは[" & moji & "]" & vbCrLf & "numは[" & num & "]"
End Function
※.NET
Sub Main(ByVal arg() As String)
Dim l_xlsApp As Object = CreateObject("Excel.Application")
l_xlsApp.Visible = True
Dim l_xlsBook As Object = l_xlsApp.Workbooks.Open("C:\Test.xls")
MsgBox(l_xlsApp.Run("Test.xls!test", "あいうえお", 5))
l_xlsBook.Close()
l_xlsBook = Nothing
l_xlsApp.Quit()
l_xlsApp = Nothing
End Sub
No.1
- 回答日時:
呼ばれるマクロの方の引数の指定に
ByVal とかを付けないようにしたらどうですか?
エクセルのマクロの本
『Excel VBA 実用サンプルコレクション』SOFTBANK
には
myStr = "piyopiyo"
Application.RUN "hogehoge", myStr
の形式のサンプルが載っています。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) エクセルのマクロについて教えてください。 4 2023/07/03 09:11
- Excel(エクセル) Excelにて、フォルダ内のTextファイルをマクロで統合すると文字化けしてしまう時の解消コード 4 2023/01/01 07:32
- Visual Basic(VBA) エクセルのマクロについて教えてください。 7 2023/07/04 09:18
- Visual Basic(VBA) VBAでfunctionを利用しようとしたときに「引数は省略できません」というエラーが出ます 1 2022/10/15 16:30
- Excel(エクセル) Excel-VBAの「しばらくお待ちください」のダイアログが自動的に閉じない 2 2023/05/24 15:31
- Excel(エクセル) 【マクロ】フォルダを3つ、POモニター上に、決まった並べ方をしたい 4 2022/08/31 11:05
- Visual Basic(VBA) VBAでoutlook365が起動しません。 4 2022/08/25 13:31
- Visual Basic(VBA) エクセルのマクロについて教えてください。 2 2023/07/15 15:48
- Visual Basic(VBA) VBA シート上にドロップダウンリストを作り、予め指定値をセットしたいのですが 1 2023/03/25 15:15
- Excel(エクセル) Excel マクロで For 文のインデックスを先に宣言する理由 7 2022/08/27 00:26
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
特定のPCだけ動作しないVBAマク...
-
Excel・Word リサーチ機能を無...
-
メッセージボックスのOKボタ...
-
Excel マクロ VBA プロシー...
-
エクセルで特定の列が0表示の場...
-
TERA TERMを隠す方法
-
wordを起動した際に特定のペー...
-
一つのTeratermのマクロで複数...
-
ExcelVBAでPDFを閉じるソース
-
特定文字のある行の前に空白行...
-
マクロ実行時、ユーザーフォー...
-
Excel VBAからAccessマクロを実...
-
EXCELマクロでのThisisWor...
-
ExcelVBA 図形をクリックした...
-
ExcelのVBA。public変数の値が...
-
非表示の列をすべて削除するマクロ
-
EXCELのVBAでRange("A1:C4")を...
-
VBAで特定の文字を含まない列の...
-
uwscの使い方について。ifの前...
-
エクセル マクロ 指定日の指定...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excel・Word リサーチ機能を無...
-
エクセルで特定の列が0表示の場...
-
特定のPCだけ動作しないVBAマク...
-
Excel マクロ VBA プロシー...
-
メッセージボックスのOKボタ...
-
一つのTeratermのマクロで複数...
-
ExcelのVBA。public変数の値が...
-
Excel VBAからAccessマクロを実...
-
EXCELのVBAでRange("A1:C4")を...
-
ExcelVBAでPDFを閉じるソース
-
エクセルに張り付けた写真のフ...
-
エクセルで別のセルにあるふり...
-
TERA TERMを隠す方法
-
2つのマクロでチェックボックス...
-
マクロ実行時、ユーザーフォー...
-
【マクロ】1つのマクロの中に...
-
ピボットテーブルでの毎回可変...
-
特定文字のある行の前に空白行...
-
エクセルのマクロについて教え...
-
wordを起動した際に特定のペー...
おすすめ情報