変数やオブジェクトの型を確認する方法
スポンサーリンク
Excel VBA で変数やオブジェクトの型を調べるには TypeName を使用します。 TypeName は引数に与えられたデータの方を文字列で返します。
数値など基本的なデータの型を確認するサンプル
基本的なデータの型を調べるをサンプルコードは次の通りです。
VBA(実行可能なサンプルコード) | |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | Option Explicit Sub test() Dim intA Dim strB Dim blnC intA = 5 strB = "5" blnC = False Debug.Print TypeName(intA) Debug.Print TypeName(strB) Debug.Print TypeName(blnC) '値からデータ型を直接確認することもできる Debug.Print TypeName(123) Debug.Print TypeName("123") Debug.Print TypeName(True) End Sub |
実行結果は次の通りです。
実行結果(イミディエイト ウインドウの表示内容) | |
1 2 3 4 5 6 | Integer String Boolean Integer String Boolean |
オブジェクトの型を確認するサンプル
オブジェクトの型を調べるサンプルコードは次の通りです。
VBA(実行可能なサンプルコード) | |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | Option Explicit Sub test() Dim objBook Dim objSheet Dim objRange Dim objCells Set objBook = ThisWorkbook Set objSheet = objBook.Worksheets(1) Set objRange = objSheet.Range("A1:B3") Debug.Print TypeName(objBook) Debug.Print TypeName(objSheet) Debug.Print TypeName(objRange) End Sub |
実行結果は次の通りです。
実行結果(イミディエイト ウインドウの表示内容) | |
1 2 3 | Workbook Worksheet Range |
初期化していない変数は Empty になる
宣言だけして代入していない変数の場合、 TypeName は Empty という文字列を返します。
VBA(実行可能なサンプルコード) | |
1 2 3 4 5 6 7 8 9 10 11 12 | Option Explicit Sub test() Dim intA Dim strB Dim blnC '代入していない場合は Empty Debug.Print TypeName(intA) Debug.Print TypeName(strB) Debug.Print TypeName(blnC) End Sub |
実行結果は次の通りです。
実行結果(イミディエイト ウインドウの表示内容) | |
1 2 3 | Empty Empty Empty |
スポンサーリンク
- エクセルVBA
- Debug.Print が出力するウインドウを表示する方法
- オブジェクトが空(Nothing)であるかを調べる方法
- R1C1 形式で範囲を指定する方法
- 変数やオブジェクトの型を確認する方法
- yyyymmdd 形式の文字列で現在日付を取得する方法
- 新しいブックを作成して保存する方法
- yyyymmdd 形式の文字列や数値を Date 型に変換する方法
- yyyymmdd 形式の文字列や数値が正しい日付かを判定する方法
- OKボタンだけのダイアログを使用する方法
- Yes/No ダイアログを使用する方法
- Yes/No/Cancel ダイアログを使用する方法
- ダイアログのメッセージを途中で改行する方法
- ソースコードが長い時に途中で改行する方法
- 文字列の一部を置換する方法
- 処理を一時停止する方法
- Select Case で条件分岐する方法
- 半角を全角に変換、全角を半角に変換する方法
- 大文字と小文字を変換する方法
- 「プログラミングによる Visual Basic プロジェクトへのアクセスは信頼性に欠けます」と表示される場合の対処法
- 呼び出すプロシージャを文字列で指定する方法
- ワークシート
- 全てのシートをコピーする方法
- シート数を確認する方法
- シートをコピーして名前を変更する方法
- 指定した名前のシートが存在するかを確認する方法
- シートを削除する方法
- 名前を指定してシートを追加する方法
- 全てのシートをループして処理する方法
- 配列
- 配列のサイズを動的に変更する方法
- For Each で配列の全ての要素を処理する方法
- 2個の配列をマージする方法
- ファイル・フォルダ
- テキストファイルに書き込む方法(Shift-JIS)
- UTF-8など文字コードを指定してテキストファイルに書き込む方法
- ファイルの更新日時を取得する方法
- フォルダ内のファイル数を取得する方法
- フォルダ内のファイルとフォルダの一覧を取得する方法
- ファイルをコピーする方法
- パスからファイル名を取得する方法
- 拡張子無しのファイル名を取得する方法
- ファイルの拡張子を取得する方法
- ファイルの作成日時、更新日時を取得する方法
- VBAを実行中のファイルが格納されたフォルダのパスを取得する方法
- ファイルが存在するかを確認する方法
- Dictionary
- Dictionary の要素数をカウントする方法
- Dictionary の要素を全て削除する方法
- Dictionary の要素を削除する方法
- Dictionary をループして処理する方法
- Dictionary の要素の値を変更する方法
- Dictionary に指定したキーが存在するかを確認する方法
- Dictionary に要素を追加する方法
- Dictionary でキーの大文字と小文字を区別しないようにする方法
- SQL Server接続
- ExcelでADODBの参照設定を行う方法
- DELETE文を実行して削除件数を取得する方法
- SELECT文を実行して抽出結果をシートに出力する方法
- UPDATE文を実行して更新件数を取得する方法
- INSERT文を実行して登録件数を取得する方法
- ストアドプロシージャに引数を渡して実行する方法
- ストアドプロシージャを実行して戻り値を受け取る方法
- プリペアドステートメントで SQLを実行する方法