ExcelマクロVBA入門
第105回.Callステートメント

Excelマクロの基礎と応用、エクセルVBAの入門・初級・初心者向け解説
最終更新日:2018-02-06

第105回.Callステートメント


プロシージャーの中で、他のプロシージャーを呼び出すときに使います、


SubプロシージャーやFunctionプロシーシ゜ャーに制御を渡すステートメントです。

プロシージャーは適切な機能単位で作ります、

適切な機能単位で作られたプロシージャーを、他のプロシージャーで使う時に、Callステートメントで呼び出します。

プロシージャーをどのような単位で作るかについては、
プログラミングの基本~ロジックの組み立て
プログラミングの基本というとプログラミング言語の基本文法についての解説と思われるかもしれませんがここではプログラミングする上で最も大切な考え方ロジックの組み立て方について解説します本来は言語は問わないのですがVBAのサイトですのでVBAを例に解説します。何かをしようとしたときどのような手順になるか… これが重要です。
こちらを参考にしてください。


Callステートメント

[Call] name [argumentlist]

Callは、
省略可能なキーワードです。
指定するときは、引数リスト (引数 argumentlist) をかっこで囲む必要があります。

nameは、
必ず指定します。
呼び出すプロシージャの名前を指定します。

argumentlistは、
省略可能です。
呼び出すプロシージャーにデータを渡すための引数です。



使用例.



Sub sample1()
  ・・・処理・・・
End Sub

Sub sample2(arg1, arg2)

  ・・・処理・・・

End Sub


上記Subプロシージャーに制御を渡す場合、

Sample1
Call Sample1
sample2 arg1, arg2
Call sample2(arg1, arg2)

このように、Callを省略する場合は、引数リストはかっこで囲わずに、
Callを記述した場合は、引数リストはかっこで囲います。

かっこの使い方については、以下で詳細に世界節しています。
VBAにおける括弧()の使い方
メソッドやSubやFunctionを呼ぶときに引数を括弧()で囲うのか囲わないのか・・・初心者が赤い文法エラーがでて悩むことの一つです。まず基本系から オブジェクト.メソッド引数1,引数2,引数3 Callオブジェクト.メソッド(引数1,引数2,引数3) Set変数=オブジェクト.メソッド(引数1,


制御先のプロシージャーが終了した後は、Callの次のステートメントに制御が移ります。



Sub sample1()
  ・・・処理A・・・
  Call sample2

  ・・・処理B・・・

End Sub

Sub sample2()

  ・・・処理C・・・

End Sub


上記では、

処理A→処理C→処理B

の順に処理されます。



引数の使い方については、次々回の、
第107回.プロシージャーの引数
SubプロシージャーFunctionプロシージャーにおける引数リストの指定について説明します引数は呼び出し先のプロシージャーに渡すデータを指定するものです。Callステートメントでプロシージャーを呼び出すときに指定する引数を呼び出される側のプロシージャーで受け取る記述についての説明になります。
こちらで解説しています。



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

Intersectメソッド
Unionメソッド
GetPhoneticメソッドとSetPhoneticメソッド(フリガナ)
Callステートメント
Functionプロシージャー
プロシージャーの引数
変数の適用範囲(スコープ,Private,Public)
列挙型(列挙体)Enum
ユーザー定義型(構造体)Type
静的配列
動的配列(Redim)


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

IfステートメントとIIF関数とMax関数の速度比較|VBA技術解説(6月23日)
Withステートメントの実行速度と注意点|VBA技術解説(6月6日)
VBA+SeleniumBasicで検索順位チェッカー(改)|VBA技術解説(6月2日)
マクロでShift_JIS文字コードか判定する|VBA技術解説(6月1日)
Shift_JISのテキストファイルをUTF-8に一括変換|VBAサンプル集(5月31日)
「VBAによる解析シリーズその2 カッコ」をやってみた|エクセル(5月21日)
VBA+SeleniumBasicで検索順位チェッカー作成|VBA技術解説(5月18日)
テーブル操作のVBAコード(ListObject)|VBA入門(5月12日)
テーブル操作の概要(ListObject)|VBA入門(5月12日)
VBAのスクレイピングを簡単楽にしてくれるSelenium|VBA技術解説(5月6日)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
3.RangeとCellsの使い方|ExcelマクロVBA入門
4.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
5.変数とデータ型(Dim)|ExcelマクロVBA入門
6.ひらがな⇔カタカナの変換|エクセル基本操作
7.繰り返し処理(For Next)|ExcelマクロVBA入門
8.マクロって何?VBAって何?|ExcelマクロVBA入門
9.空白セルを正しく判定する方法(IsEmpty,IsError,HasFormula)|VBA技術解説
10.ExcelマクロVBAの基礎を学習する方法|エクセルの神髄


  • >
  • >
  • >
  • Callステートメント

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


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






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