指定した文字列を数値に変換する(Val 関数)
Val 関数 の使い方
Val 関数は、指定した文字列に含まれる数字を数値として認識し、その値を適切なデータ型に変換してかえす関数です。
result = Val ( expression )
引数・戻り値
- expression ・・・ 任意の文字列・文字列式を指定します。
- result ・・・ 引数 expression に含まれる数値を適切なデータ型に変換した値。
文字列中の数字以外の文字を見つけると Val 関数は読み込みを中止します。ただし、スペース、タブ、ラインフィード、キャリッジリターン等は無視されます。
例1:Val(“12 345”) ⇒ 12345([スペース]は無視)
例2:Val(“99\123”) ⇒ 99([\]以降は読み込み中止)
8 進数を表す &O や 16 進数を表す &H は、数値として認識します。
例:Val(“&H10”) ⇒ 16, Val(“&O10”) ⇒ 8 )
ピリオド (.) は、小数点の記号として認識します。
例:Val(“123.55”) ⇒ 123.55
引数 expression が、Null 値の場合は、エラーになります。
引数 expression が、Empty 値の場合は、0 を返します。
Val 関数 の使用例
サンプルVBAソース
|
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 |
Sub Sample_val() Debug.Print Val(123456) '数値 Debug.Print Val("9\12") '「\」を含む Debug.Print Val("&H10") '16進数 Debug.Print Val("&O10") '8進数 Debug.Print Val("123abc") '全角数値と文字列 Debug.Print Val("123abc") '半角数値と文字列 Debug.Print Val("25.1") '小数点を含む数値 Debug.Print Val(50 & Chr(9) & "11") '水平タブ Debug.Print Val(60 & Chr(10) & 1) 'ラインフィード Debug.Print Val(70 & Chr(11) & 1) '垂直タブ Debug.Print Val(80 & Chr(13) & 1) 'キャリッジリターン Debug.Print Val(90 & Chr(32) & 1) 'スペース End Sub |
実行結果
関連記事
-
-
対象のオブジェクトをクリアする(Clear メソッド)
Clear メソッド 対象となるオブジェクト全体をクリアします。Range オブ …
-
-
VBA の演算子(演算子の優先順位)
演算子の優先順位 演算子の優先順位とは、1つの式の中に演算子が複数ある場合、どの …
-
-
文字列:定数(改行・タブ)
改行・タブの定数 これらの定数は、使用前に定義する必要はありません。コード中のど …
-
-
配列の要素数を取得する(UBound 関数・LBound 関数)
UBound 関数・LBound 関数 【書式】 result = UBound …
-
-
指定した値を16進数で表記した文字列に変換する(Hex 関数)
Hex 関数 の使い方 【書式】 result = Hex ( expressi …
-
-
VBA で正規表現を使う(RegExp オブジェクト)
RegExp オブジェクト VBA で正規表現を使うには、VBScript のR …
-
-
日付時刻:文字列から日付・時刻データを取得( DateValue 関数、TimeValue 関数 )
DateValue 関数(文字列から日付データを取得) 【書式】 date_va …
-
-
Math 関数( Abs,Atn,Cos,Exp,Log,Rnd,Sgn,Sin,Sqr,Tan )
Abs 関数 【書式】 value = Abs ( number ) 【引数・戻 …
-
-
セルのデータを固定長形式で複数のセルに分割する(TextToColumns メソッド・Parse メソッド)
固定長形式でセルを分割 TextToColumns メソッドや Parse メソ …
-
-
VBA で正規表現を使う(RegExp オブジェクトのメソッド)
RegExp オブジェクトのメソッド RegExp オブジェクトの詳細に関しては …
