【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]Log WriterLet’s log this. 【VBA】ログをファイル出力するクラス|LogWriter -

[VBA]Vertical Paste1D array 【VBA】一次元配列を縦方向にシートに貼り付け【範囲をリサイズする】 -

UsedRangeのデータを配列で取得 【VBA】シートにあるデータを配列に格納する(空白含む)|UsedRange -

[VBA]ClearContentsシート初期化 【VBA】シートの初期化|ClearContentsで値のみ削除 -

[VBA]Trimwhitespace 【VBA】先頭,末尾,両端の空白を削除する|Trim -

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