配列の添字の最小値を「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」が表示されます。
関連記事
-
-
変数が数値型かどうかをチェックする( IsNumeric 関数 )
IsNumeric 関数の使い方 【書式】 result = IsNumeric …
-
-
文字列:文字列を指定した形式に変換する(StrConv 関数)
StrConv 関数の使い方 【書式】 result = StrConv ( s …
-
-
セルのデータを固定長形式で複数のセルに分割する(TextToColumns メソッド・Parse メソッド)
固定長形式でセルを分割 TextToColumns メソッドや Parse メソ …
-
-
変数がNull 値かどうかをチェックする( IsNull 関数 )
IsNull 関数の使い方 【書式】 result = IsNull ( exp …
-
-
日付時刻:日付時刻データを計算( DateAdd 関数 )
DateAdd 関数(日付・時刻の値を加算・減算結果を取得) 【書式】 resu …
-
-
ショートカットメニュー(CommandBar オブジェクト)
ショートカットメニュー(コンテキストメニュー) 右クリックで表示されるメニューの …
-
-
文字列:文字列を最後から検索してその最初の文字位置を返す(InStrRev 関数)
InStrRev 関数 任意の文字列の中で、指定した文字列を最後から検索して、見 …
-
-
指定した値を16進数で表記した文字列に変換する(Hex 関数)
Hex 関数 の使い方 【書式】 result = Hex ( expressi …
-
-
配列(宣言・要素数の変更について)
配列の宣言 【書式】※ 配列の宣言 <Type 型の静的配列(固定長配列)の宣言 …
-
-
xlFileFormat 列挙型
xlFileFormat 列挙型 Workbook.SaveAs メソッド の引 …



