VBA入門
第25回.名前付き引数について

ExcelマクロVBAの基本と応用、エクセルVBAの初級・初心者向け解説
最終更新日:2020-09-26

第25回.名前付き引数について


引数とは、関数やメソッド等を呼び出すときに渡す値の指定のことです。
この引数を渡す時の記述方法として、名前付き引数があります。


マクロVBAでの記述では、:=が使われます。
この:=名前付き引数のみで使用される記述になります。

仮引数と実引数

仮引数とは、関数・メソッド定義時に使用される引数の事です。
実引数とは、その関数・メソッドを実際に使用するときに引き渡す引数の事です。
このマクロVBAシリーズでは特にこれらを区別することなく、単に「引数」と表記しています。

メソッドとは

methodであり、方法・方式です。オブジェクトに対する動作・操作を指定します。
セルを選択する、セルを削除する等ですが、今後少しずつ説明していきます。

エクセルの言葉を理解する(オブジェクト、プロパティ、メソッド)
VBAを書いて実行すると、何やら難しい日本語らしきメッセージが表示されることがあります。エクセルが何かを伝えようとしている訳ですが、何を言っているのかを理解してあげなければエクセルがかわいそうです。かわいそうと言うのはともかくとして、エクセルが表示するエラーメッセージの言葉の意味くらいは知っておきたいところです。

名前付き引数について

通常、複数の引数がある場合は、その順番通りに指定します。
先頭より、
第1引数, 第2引数, 第3引数, ・・・ 
と呼びます。
しかし、
引数の数が多いと、何番目なのかを意識することは面倒になりますし混乱します。
そこで、
引数に名前を付けて、その名前で指定できるようになっています
それが、
名前付き引数です。

名前付き引数を指定する場合は、
名前付き引数名:=値
このように、:=で値を指定します。

名前付き引数の例文

MsgBox関数での名前付き引数の使用例です。

MsgBox(prompt[, buttons] [, title] [, helpfile, context])



MsgBox "出来ました。", vbOKOnly, "タイトル"

としましたが、この引数は順番通りに指定する必要があります
名前付き引数を使って指定すると、

MsgBox prompt:="出来ました。", Buttons:=vbOKOnly, Title:="タイトル"

これは、



MsgBox Title:="タイトル", Buttons:=vbOKOnly, prompt:="出来ました。"

このように、名前付き引数を使えば、順番を変更しても問題ありません
また、名前付き引数を使わない場合は、途中の引数を省略する場合は、

MsgBox "出来ました。", , "タイトル"

このように、, , のように、引数の位置は正しく指定する必要があります
しかし、名前付き引数を使えば、

MsgBox prompt:="出来ました。", Title:="タイトル"

このように、名前付き引数を使えば、引数の位置を意識することなく指定できます

名前付き引数の必要性

出来る限り、名前付き引数を使う事が望ましいのですが、
全ての関数・メソッドで名前付き引数を使うのは少々面倒な時もあります。

上記の例のMsgBox関数のように、
関数は多くの人が、その引数の順番を知っているので特に名前付き引数を使う必要がない場合が多いです。
しかし、
メソッドにおいては、引数の数がとても多いものがあります。
そして、
その引数の意味や順番を記憶している人は少ないでしょう。
従って、
名前付き引数を使う事で、より解り易いマクロVBAにすることが出来ます。
つまり、
名前付き引数は、マクロVBAを読みやすくするためにあるものだと考えてください。



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

第22回.条件分岐(Select Case)
第23回.メッセージボックス(MsgBox関数)
第24回.インプットボックス(InputBox関数)
第25回.名前付き引数について
第26回.総合練習問題2
第27回.ブック・シートの選択(Select,Activate)
第28回.セル・行・列の選択(Select,ActivateとCurrentRegion)
第29回.セル・行・列の削除・挿入(Delete,Insert)
第30回.総合練習問題3
第31回.セルの書式(表示形式,NumberFormatLocal)
第32回.セルの書式(配置,Alignment)


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

VBA100本ノック 61本目:「ふりがな」の取得と設定|VBA練習問題(1月6日)
VBA100本ノック 60本目:「株式会社」の表記ゆれ置換|VBA練習問題(1月5日)
VBA100本ノック 59本目:12ヶ月分のシートを四半期で分割|VBA練習問題(1月4日)
Select Caseでの短絡評価(ショートサーキット)の使い方|VBA技術解説(1月3日)
VBA100本ノック 迷宮編:巡回セル問題|VBA練習問題(12月31日)
VBA100本ノック 58本目:番号リストを簡潔にした文字列で返す|VBA練習問題(12月30日)
VBA100本ノック 57本目:ファイルの更新日時|VBA練習問題(12月29日)
VBA100本ノック 56本目:数式内の自身のシート名を消す|VBA練習問題(12月28日)
VBA100本ノック 55本目:他ブックのマクロを起動|VBA練習問題(12月26日)
VBA100本ノック 54本目:シートのChangeイベント|VBA練習問題(12月25日)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.マクロって何?VBAって何?|VBA入門
5.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
6.繰り返し処理(For Next)|VBA入門
7.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
8.セルに文字を入れるとは(Range,Value)|VBA入門
9.とにかく書いてみよう(Sub,End Sub)|VBA入門
10.繰り返し処理(Do Loop)|VBA入門




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


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



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