ExcelマクロVBA入門 | 第127回.他のブックのマクロを実行(Runメソッド) | Excelマクロの基礎と応用、エクセルVBAの入門・初級・初心者向け解説



最終更新日:2018-02-08

第127回.他のブックのマクロを実行(Runメソッド)


他のブック中にあるプロシージャー(Sub,Function)を実行する場合は、Application.Runメソッドを使います。

別々に作成されたマクロの入ったブックを連携させる時には必須になります。



Runメソッド
マクロの実行または関数の呼び出しを行います。

Application.Run(Macro, Arg1, Arg2, Arg3, ・・・, Arg30)

Macro オプション 実行するマクロを指定します。

他ブックのマクロの場合は、
ブック名!プロシージャー名

と指定します。
Arg1-Arg30 オプション 関数に渡す引数を指定します。

このメソッドの引数では、名前付き引数は使用できません。

Run メソッドは、呼び出したマクロが返す値をそのまま返します。



使用例.

Book1.xls

Sub test1(arg1 As String)
  MsgBox arg1
End Sub

Book2.xls

Sub test2()
  Call Application.Run("Book1.xls!test1", "ブック間のマクロテスト")
  'または
  'Application.Run "Book1.xls!test1", "ブック間のマクロテスト"
End Sub

tset2を実行すると、
ブック間のマクロテスト
と、メッセージボックスに表示されます。



本来は、このようなブック間でプロシージャーを起動することは、あまり望ましい状態ではありません。

ブックの依存関係をしっかり設計すれば、このような状態はほとんど避けられるはずです。

しかし、後から追加していく形でシステムを拡張していくと、どうしてもこのような手段が必要になることもあります。

そのような時のためにも、一応は抑えておきたい機能になります。




同じテーマ「マクロVBA入門」の記事

第119回.ファイルシステムオブジェクト(FileSystemObject)
第120回.OnTimeメソッド
第121回.SendKeysメソッドとAppActivateステートメント
第122回.Shell関数
第123回.APIについて(Win32API)
第124回.Workbookのイベントプロシージャー
第125回.Worksheetのイベントプロシージャー
第126回.入力規則(Validation)
第128回.マクロをショートカットで起動(OnKeyメソッド)
第129回.レジストリの操作(SaveSetting,GetSetting,GetAllSettings,DeleteSetting)

新着記事 ・・・新着記事一覧を見る

For Next の使い方いろいろ|VBA技術解説(6月14日)
VBAを定型文で覚えよう|ExcelマクロVBA技術解説(3月26日)
VBAスタンダード試験対策まとめ|MOS VBAエキスパート対策(3月16日)
ユーザーフォームとメニューの操作|MOS VBAエキスパート対策(3月14日)
ファイルの操作|MOS VBAエキスパート対策(3月14日)
ユーザーフォームの各種イベント|Excelユーザーフォーム(3月13日)
レジストリの操作|MOS VBAエキスパート対策(3月12日)
変数と配列|MOS VBAエキスパート対策(3月12日)
Colorプロパティの設定値一覧|VBA技術解説(3月12日)
APIとOLEオートメーション|MOS VBAエキスパート対策(3月11日)

アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|VBA入門
2.変数とデータ型(Dim)|ExcelマクロVBA入門
3.マクロって何?VBAって何?|ExcelマクロVBA入門
4.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
5.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
6.RangeとCellsの使い方|ExcelマクロVBA入門
7.とにかく書いて見よう(Sub,End Sub)|VBA入門
8.まずはマクロVBAを使う準備|ExcelマクロVBA入門
9.繰り返し処理(For Next)|ExcelマクロVBA入門
10.マクロはどこに書くの(VBEの起動)|VBA入門



  • >
  • >
  • >
  • 他のブックのマクロを実行(Runメソッド)

  • このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


    記述には細心の注意をしたつもりですが、
    間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
    なお、掲載のVBAコードは自己責任で使ってください。万一データ破損等の損害が発生しても責任は負いません。





    このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。

    本文下部へ

    ↑ PAGE TOP