変数がNull 値かどうかをチェックする( IsNull 関数 )
IsNull 関数の使い方
result = IsNull ( expression )
【引数・戻り値】
- expression ・・・ 調べる変数や式
- result ・・・ 引数 expression が、Null 値を含んでいるかどうかを調べた結果
(ブール型:Null 値を含む場合は、True / そうでなければ、False )。
変数が Null 値 である場合とは、有効なデータが入っていないことを示す値のことです。変数が初期化されていない場合( Empty )、長さ「0」の文字列( Null文字 )の場合とは異なります。
引数 expression が複数の変数で構成されている場合、その中の変数が1つでも Null 値の場合は、式全体が Null 値となります。(※ ただし、「&」演算子を使用した場合は複数の変数があっても Null 値とならない場合もあります。⇒ 「VBA の演算子(文字連結演算子:& 演算子 + 演算子)」を参照)
If ステートメント等を使って、
If value = Null then …
If value <> Null then …
とした場合、いずれの式も False(偽)と評価されてしまいます。これは Null 値を含む式は、式自体が Null 値となり、偽 (False) と評価されるためです。
IsNull 関数の使用例
サンプルVBAソース<その1>
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 |
Sub Sample_isnull01() Dim myVal1, myVal2, myVal3, myVal4, myVal5, myVal6, myVal7 myVal2 = "" myVal3 = 0 myVal4 = Empty myVal5 = 123 myVal6 = "こんばんは" myVal7 = Null 'False Debug.Print IsNull(myVal1) Debug.Print IsNull(myVal2) Debug.Print IsNull(myVal3) Debug.Print IsNull(myVal4) Debug.Print IsNull(myVal5) Debug.Print IsNull(myVal6) 'True Debug.Print IsNull(myVal7) Debug.Print IsNull(myVal1 + myVal7) Debug.Print IsNull(myVal2 + myVal7) Debug.Print IsNull(myVal3 + myVal7) Debug.Print IsNull(myVal4 + myVal7) Debug.Print IsNull(myVal5 + myVal7) Debug.Print IsNull(myVal6 + myVal7) End Sub |
実行結果(その1)
サンプルVBAソース<その2>
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
Sub Sample_isnull02() 'Null を含む式は全て偽(False)となるため 'メッセージボックスには、「ccc」と表示されます。 Dim myVal If myVal = Null Then MsgBox "aaa" ElseIf myVal <> Null Then MsgBox "bbb" Else MsgBox "ccc" End If End Sub |
実行結果(その2)
関連記事
-
-
文字列:文字列の一部を別の文字列で置換(Replace 関数)
Replace 関数の使い方 【書式】 result = Replace ( s …
-
-
ユーザー定義関数:自動再計算関数の設定(Volatile メソッド)
ユーザー定義関数で、自動再計算を行うかどうかを設定する ワークシート上で使用する …
-
-
日付時刻:文字列から日付・時刻データを取得( DateValue 関数、TimeValue 関数 )
DateValue 関数(文字列から日付データを取得) 【書式】 date_va …
-
-
VBA の演算子(論理演算子:And、Eqv、Imp、Not、Or、Xor)
論理演算子 論理演算を行うときに使用する演算子で、以下の 6 種類があります。 …
-
-
文字列:文字列の指定した位置から指定文字数取得(Mid 関数,MidB 関数)
Mid 関数・MidB 関数 の使い方 【書式】 result_mid = Mi …
-
-
文字列:文字列変数内の一部を置き換える(Mid・MidB ステートメント)
Mid・MidB ステートメントの使い方 【書式】 { Mid | MidB } …
-
-
xlFileFormat 列挙型
xlFileFormat 列挙型 Workbook.SaveAs メソッド の引 …
-
-
乱数を生成する(Rnd 関数)
Rnd 関数の使い方 Rnd 関数は、0 以上、1 未満の範囲の乱数を単精度浮動 …
-
-
指定したセル範囲のサイズを変更(Resize プロパティ)
Resize プロパティ 指定したセル範囲のサイズ(行数や列数)を変更します。 …
-
-
オートシェイプの種類を表す定数(MsoAutoShapeType 列挙型)
MsoAutoShapeType 列挙型 オートシェイプオブジェクトの図形の種類 …

