ツイッター出題回答
m/d/yyyy形式文字列を日付シリアル値に変換

ExcelマクロVBAとエクセル関数についての私的雑感
公開日:2022-07-07 最終更新日:2022-07-07

m/d/yyyy形式文字列を日付シリアル値に変換


ツイッターで出題した問題です。


エクセルでは、「m/d/yyyy」形式で入力しても文字列として扱われてしまいます。
そこで、「m/d/yyyy」を日付のシリアル値に変換する数式を考える問題です。


出題ツイート

「エクセル頭の体操」日付基本編
m/d/yyyy
この形式で入力しても、それは文字列として入力されてしまいます。
そこで、これを日付データに変換する数式を作成してください。
結果はシリアルで良い、見た目は表示形式で。
※指定形式以外のデータはエラーで構わない


Excel エクセル 問題 クイズ
https://twitter.com/yamaoka_ss/status/1544566387443527681


引用リツイートでの回答

出題者としての解答

文字列の「m/d/yyyy」を日付(シリアル値)にします。
右の4桁が年なので、
RIGHT(A1,4)
これで年が取れます。
/yyyyこれが5桁なので、全文字数-5がm/dの部分になります。
=(RIGHT(A1,4)&"/"&LEFT(A1,LEN(A1)-5))*1
これが短くて簡単だと思います。


文字列日付をシリアル値にするにはDATEVALUE関数を使います。
ただし日付と認識される文字列はそのまま計算に使えるので、何らかの計算をすればシリアル値になります。
()*1
()+0
-()
文字数も同じなのでどれでも良いと思います。
もちろん文字数気にせずにDATEVALUE関数を使って構いません。


今回は「m/d/yyyy」で固定でしたが、
例えば「m/d/yy」も混ざっている場合はどうでしょうか。
やり方はいろいろありそうですが、
2番目の「/」の位置を取得して分割すれば良さそうです。
=--(RIGHT(A1,LEN(A1)-FIND("/",A1,4))&"/"&LEFT(A1,FIND("/",A1,4)-1))
ご参考まで。


Excel エクセル 問題 クイズ
https://twitter.com/yamaoka_ss/status/1544934115073396736




同じテーマ「ツイッター出題回答 」の記事

コメントから特定形式の年月を取り出す
抜けている数値を探せ
15桁を超える数値の足し算
m/d/yyyy形式文字列を日付シリアル値に変換
成績表(ネ申エクセル)を別表に集計
年月に対して有効な日だけの入力規則のリスト作成
8桁数値が日付として不適切なら赤にする条件付き書式
条件付きの最大値と中央値("A"が2文字の条件)
日付時刻のマイナス表示に対応する方法
一覧から複数条件(部分一致、範囲)に合致するデータを抽出する
構成比を合計しても100%にならないと言われた…


新着記事NEW ・・・新着記事一覧を見る

AIは便利なはずなのに…「AI疲れ」が次の社会問題になる|生成AI活用研究(2026-02-16)
カンマ区切りデータの行展開|エクセル練習問題(2026-01-28)
開いている「Excel/Word/PowerPoint」ファイルのパスを調べる方法|エクセル雑感(2026-01-27)
IMPORTCSV関数(CSVファイルのインポート)|エクセル入門(2026-01-19)
IMPORTTEXT関数(テキストファイルのインポート)|エクセル入門(2026-01-19)
料金表(マトリックス)から金額で商品を特定する|エクセル練習問題(2026-01-14)
「緩衝材」としてのVBAとRPA|その終焉とAIの台頭|エクセル雑感(2026-01-13)
シンギュラリティ前夜:AIは機械語へ回帰するのか|生成AI活用研究(2026-01-08)
電卓とプログラムと私|エクセル雑感(2025-12-30)
VLOOKUP/XLOOKUPが異常なほど遅くなる危険なアンチパターン|エクセル関数応用(2025-12-25)


アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|VBA入門
2.日本の祝日一覧|Excelリファレンス
3.変数宣言のDimとデータ型|VBA入門
4.FILTER関数(範囲をフィルター処理)|エクセル入門
5.RangeとCellsの使い方|VBA入門
6.繰り返し処理(For Next)|VBA入門
7.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
8.マクロとは?VBAとは?VBAでできること|VBA入門
9.セルのクリア(Clear,ClearContents)|VBA入門
10.メッセージボックス(MsgBox関数)|VBA入門




このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


記述には細心の注意をしたつもりですが、間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。
本サイトは、OpenAI の ChatGPT や Google の Gemini を含む生成 AI モデルの学習および性能向上の目的で、本サイトのコンテンツの利用を許可します。
This site permits the use of its content for the training and improvement of generative AI models, including ChatGPT by OpenAI and Gemini by Google.



このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
本文下部へ