【VBA】日付型を文字列にする|Format
作成日:2022-11-01
更新日:2025-10-06

Formatを
使う
使う
Format|「意図した見た目」にできる
Sub Test_DateTime_Format()
Dim d As Date
Dim s As String
' ① 時刻だけ
d = "9:00"
s = Format(d, "hh:mm:ss") '09:00:00
s = Format(d, "hhmm") '0900
' ② 日付だけ
d = "2025/10/06"
s = Format(d, "yyyy/mm/dd") '2025/10/06
s = Format(d, "yyyymmdd"). '20251006
' ③ 日付+時刻
d = "2025/10/06 9:00"
s = Format(d, "yyyy/mm/dd hh:mm:ss") '2025/10/06 09:00:00
s = Format(d, "yyyymmdd_hhmmss") '20251006_090000
End Sub

好きな形にフォーマットできる
補足|Cstrはロケール依存のため不正確
dim d as date
dim strD as string
d = "9:00"
strD = CStr(d)結果:”9:00″
※ OS依存のため、次のような結果になることもある"09:00:00"
“9:00:00 AM”

文字列だけど、見た目の指定はできない
Vocabulary
| Date Type|日付型 |
| CStr Function|CStr関数 |
| Format Function|Format関数 |
| Locale Dependency|ロケール依存性 |
| String Conversion|文字列変換 |

逆パターンはこちら
When consistency matters, always format explicitly.

同じ処理をPythonでも書いてみよう
2022-11-01
編集後記:
この記事の内容がベストではないかもしれません。
記事一覧
-

[VBA]Resizerows and columns 【VBA】Resize changes the size of a cell range|範囲のリサイズ -

[VBA]InStr文字列確認 【VBA】指定の文字列が含まれているか & 前後の文字列を返す|InStr/InStrRev -

[VBA]fsoSingleton pattern 【VBA】FSO(“Scripting.FileSystemObject”)|シングルトン化して使う -

[VBA]開いているかwith FullName 【VBA】ブックが開いているか判定|StrComp で FullNameを調べる -

[VBA]StrCompで文字列比較 【VBA】拡張子の存在確認|Right + StrComp -

Let と Getで読み取り専用 【VBA】クラスのプロパティを読み取り専用にするLet と Getの書き方