これはデートですか? という意味深な質問を投げかけるIsDate関数のご紹介です。真、偽を返すので条件分岐に使いやすく、フラグを容易に立てることができます。
IsDate関数の使い方
引数が日付かを判定
IsDate(引数)
IsDate(引数)
data:image/s3,"s3://crabby-images/b032d/b032d0bfd5a9f41b41b2f0a10673bde64fcde277" alt="isdate1"
とりあえず漢数字で日付を書きました。このA1セルを日付判断ボックスとします。
data:image/s3,"s3://crabby-images/2a395/2a39562b7a1b71356a417c98e37024d052cef036" alt="isdate2"
VBAを開き、マクロを書いていきます。
まずIf文でIsDate(Range(“A1”).Value)を判定します。日付ならTrueが返り、そうでないならFalseが返るので、これ以上の記述は不要です。
まずIf文でIsDate(Range(“A1”).Value)を判定します。日付ならTrueが返り、そうでないならFalseが返るので、これ以上の記述は不要です。
data:image/s3,"s3://crabby-images/e0d20/e0d20071c45a1f4548d6467e394dc764a7291e7e" alt="isdate3"
日付であればそうである旨、
data:image/s3,"s3://crabby-images/3d983/3d983dfc9552edfb154468c657d5bc3413022848" alt="isdate4"
ちがうならちがう旨、メッセージボックスで表示します。
data:image/s3,"s3://crabby-images/33e00/33e0096976c4692942fe060d39602b5c59dd8c53" alt="isdate5"
実行結果。一月二日と普通に書いたものは文字列とされ、日付認定されませんでした。
data:image/s3,"s3://crabby-images/7aca5/7aca55cbf31f22103756e04339b6b3e1721d3c83" alt="isdate6"
Excelが日付認定するデータは、たとえばこういう感じのものです。
data:image/s3,"s3://crabby-images/90874/90874dbfb627360ab3936294ac120b68b0f7cfd1" alt="isdate7"
自動で書式が日付になり、表記が変更されました。これは当然パスします。
data:image/s3,"s3://crabby-images/f8d14/f8d14178725d59904ff939e6f21018fcf5f049d9" alt="isdate8"
書式を変更しシリアル値にすると、これは数値として扱われます。パスしません。
data:image/s3,"s3://crabby-images/64c2e/64c2e31a6dc63bdd6b0964e9e34844cf8bf0e396" alt="isdate9"
なお、存在しない日付でもそれっぽければパスします。「今月何日までだっけ?」的な使い方はできません。
data:image/s3,"s3://crabby-images/7f2d6/7f2d6777601ebc74909cc72e0e61306d178ee252" alt="isdate10"
逆に明らかに日付でないものを書式だけ日付にしても……。
data:image/s3,"s3://crabby-images/191bf/191bfbfb82c944775858fe90b9daf14734aa6077" alt="isdate11"
これはパスしません。
' vba
If IsDate(Range("A1").Value) Then
MsgBox "日付です"
Else
MsgBox "日付ではないです"
End If
Next
IsDate関数の使い方については以上です。同様に数値を判定する場合はIsNumeric関数、空白かどうかはIsEmpty関数の記事をご参照ください。
文字列を判定したい、あるいはTrue/Falseではなくデータ型の名称を取得したい・条件に使いたい場合は、TypeName関数を使います。
data:image/s3,"s3://crabby-images/6c3a6/6c3a641a26b059d68846ac57533df8a1cc24d966" alt=""
やりたいことから方法を探すエクセル(Excel)操作・関数・VBA(マクロ)逆引きまとめ
逆引き(やりたいことから探す)Excel記事まとめ
data:image/s3,"s3://crabby-images/44b36/44b36d0f8fac0be53447fdd93eac7bc139caa294" alt=""
関数・演算子・メソッド・プロパティ名から探すExcel/VBA(マクロ)使い方・組み合わせ方まとめ
こちらはExcelやメソッドの諸機能を、機能の名称から探せるまとめ記事です。
コメント