配列の添字の最小値を「1」に設定する
2015/03/30
Option Base ステートメントを使用する
Option Base 1
添字の既定の最小値は 0 です。Option Base ステートメントを使うと既定の最小値を 1 に設定できます。
Option Base ステートメントを使用する場合は、モジュール内のどのプロシージャよりも前に記述する必要があります。Option Base ステートメントは、モジュール内で一度だけ、次元を含む配列の宣言よりも前に記述します。
Option Base ステートメントの設定が有効になるのは、ステートメントが記述されているモジュール内の配列の添字の最小値のみです。
Option Base ステートメントを設定する
モジュールの宣言セクションに Option Base 1 を指定するとモジュール内の配列の添字の最小値が「1」に設定されます。
VBAソース
1 2 3 4 5 6 7 8 9 10 11 12 |
Sub sample_option_base01() '整数型の要素3の配列 Dim strArray(3) As Integer '配列 strArray の添字の最小値・最大値を表示 MsgBox "添字開始番号:" & LBound(strArray) & Chr(13) & _ "添字終了番号:" & UBound(strArray) End Sub |
実行結果
Option Base 1 ステートメントを設定しているため添字の最小値が「1」となります。
( ※ UBound 関数・LBound 関数 は、それぞれ配列の添字の最大値・最小値を取得します。)
Option Base ステートメントに影響されない関数など
Option Base ステートメントを使用しても Split 関数や キーワード ParamArray を使って作成する配列の添字の最小値は 0 のままです。
つまり、Split 関数 や キーワード ParamArray は、Option Base ステートメントの影響を受けません。
例 Split関数(※ Array 関数 と比較)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
Sub sample_option_base02() Dim val, val2, mystr val1 = Array(1, 2, 3, 4, 5) mystr = "10,20,30,40,50" val2 = Split(mystr, ",") 'val1(1) と val2(1) の値を比較 MsgBox "val1(Array関数で取得):" & val1(1) & Chr(13) & _ "val2(Split関数で取得):" & val2(1) End Sub |
実行結果
Array 関数は、Open Base ステートメントの影響を受けるため、val1(1)は、「1」を表示します。一方、Split 関数は、Open Base ステートメントの影響を受けないため、val2(1)は、「20」を表示します。
例 キーワード ParamArray
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
'引数の配列の添字が「1」の値を返す Function get_First_el(ParamArray myArray()) As Long get_First_el = myArray(1) End Function Sub sample_option_base03() MsgBox get_First_el(11, 12, 13, 14, 15, 16, 17) End Sub |
実行結果
Option Base 1 ステートメントの影響を受けていないので、「12」が表示されます。
関連記事
-
文字列:文字列を指定した形式に変換する(StrConv 関数)
StrConv 関数の使い方 【書式】 result = StrConv ( s …
-
ショートカットメニュー(CommandBar オブジェクト)
ショートカットメニュー(コンテキストメニュー) 右クリックで表示されるメニューの …
-
オブジェクトの書式をクリアする(ClearFormats メソッド)
ClearFormats メソッド 対象となるオブジェクトの書式(スタイル)を初 …
-
文字列:アルファベットを小文字または大文字に変換(LCase 関数,UCase 関数)
LCase 関数・UCase 関数 の使い方 【書式】 <アルファベットの大文字 …
-
データ型を調べてそのデータ型を示す文字列を返す(TypeName 関数)
TypeName 関数 の使い方 TypeName 関数は、引数に、データ型を調 …
-
VBA で正規表現を使う(RegExp オブジェクトのメソッド)
RegExp オブジェクトのメソッド RegExp オブジェクトの詳細に関しては …
-
オートシェイプの種類を表す定数(MsoAutoShapeType 列挙型)
MsoAutoShapeType 列挙型 オートシェイプオブジェクトの図形の種類 …
-
変数が数値型かどうかをチェックする( IsNumeric 関数 )
IsNumeric 関数の使い方 【書式】 result = IsNumeric …
-
IME の現在の状態を取得します(IMEStatus 関数)
IMEStatus 関数の使い方 【書式】 result = IMEStatus …
-
日付時刻:日付・時刻の間隔を取得( DateDiff 関数 )
DateDiff 関数の使い方 【書式】 result = DateDiff ( …