配列の添字の最小値を「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」が表示されます。
関連記事
-
-
色の設定(ThemeColor プロパティ・TintAndShade プロパティ)
ThemeColor プロパティ・TintAndShade プロパティ テーマカ …
-
-
日付時刻:現在の日付・時刻を取得・設定(Now、Date、Time)
現在の日付・時刻を取得・設定 現在の日付・時刻を取得(Now 関数、Date 関 …
-
-
指定した数値を文字列に変換する(Str 関数)
Str 関数 の使い方 Str 関数は、数値・数式を文字列に変換して返す関数です …
-
-
フォントの設定(Font プロパティ)
フォントの設定(Font プロパティ) 指定されたオブジェクトのフォント情報(F …
-
-
文字列:文字列を最後から検索してその最初の文字位置を返す(InStrRev 関数)
InStrRev 関数 任意の文字列の中で、指定した文字列を最後から検索して、見 …
-
-
対象のオブジェクトをクリアする(Clear メソッド)
Clear メソッド 対象となるオブジェクト全体をクリアします。Range オブ …
-
-
四捨五入・切り上げ・切り捨て・丸め(Round 関数 他)
Round 関数(丸め)の使い方 【書式】 value = Round ( ex …
-
-
文字列:アルファベットを小文字または大文字に変換(LCase 関数,UCase 関数)
LCase 関数・UCase 関数 の使い方 【書式】 <アルファベットの大文字 …
-
-
指定した値を16進数で表記した文字列に変換する(Hex 関数)
Hex 関数 の使い方 【書式】 result = Hex ( expressi …
-
-
指定した文字列を数値に変換する(Val 関数)
Val 関数 の使い方 Val 関数は、指定した文字列に含まれる数字を数値として …



