- 締切済み
Excelマクロを引数付で起動
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) のようにすれば…と思っていたのですが。 ご存知の方がいらっしゃいましたら教えてください。 お願いいたします。
- みんなの回答 (4)
- 専門家の回答
みんなの回答
- Hayashi_Trek
- ベストアンサー率44% (366/818)
ANo.1 の者です。 VB.NETというのを見逃してました。 VB.NETとVBAではデータ型が異なるのですが、そこはOKでしょうか? VBAとVB.NETのデータ型の対応は VBA --- VB.NET -------------------- Integer --- Short Long --- Integer Single --- Single Double --- Double String --- String
- Wendy02
- ベストアンサー率57% (3570/6232)
こんにちは。 >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
- 1050 円(@1050YEN)
- ベストアンサー率69% (477/687)
>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
- Hayashi_Trek
- ベストアンサー率44% (366/818)
呼ばれるマクロの方の引数の指定に ByVal とかを付けないようにしたらどうですか? エクセルのマクロの本 『Excel VBA 実用サンプルコレクション』SOFTBANK には myStr = "piyopiyo" Application.RUN "hogehoge", myStr の形式のサンプルが載っています。