PHP 的 strtotime() 和 DateTime::createFromFormat() 不原生支持中文日期,因前者依赖 C 库且不识别“年月日”汉字,后者需手动指定含中文的格式并校验;中文数字须预处理转阿拉伯数字,且无统一规范需按实际输入定制逻辑。

不能直接转,PHP 的 strtotime() 和 DateTime::createFromFormat() 都不原生识别“二〇二四年三月十五日”或“2024年3月15日”这类含中文年月日标识的字符串。
为什么 strtotime() 对中文日期基本失效
它依赖 C 库的 locale 解析逻辑,而中文字符(如“年”“月”“日”)不在其默认识别词表中。即使设置 setlocale(LC_TIME, 'zh_CN.UTF-8'),strtotime() 依然无法解析这些汉字单位。
- 输入
"2024年3月15日"→ 返回false或错误时间戳 - 输入
"二〇二四年三月十五日"→ 完全无法识别,因为还涉及中文数字转换 - 仅当字符串是纯 ASCII 格式(如
"2024-03-15"、"15/03/2024")时才可靠
用 DateTime::createFromFormat() 手动指定格式
这是最可控的方式,但前提是中文字符必须被显式写进格式字符串里 —— PHP 支持在格式中混用中文文字,只要它们与输入字符串完全一致。
date_default_timezone_set('Asia/Shanghai');
$zhDate = '2024年3月15日';
$dt = DateTime::createFromFormat('Y年n月j日', $zhDate);
if ($dt && $dt->format('Y年n月j日') === $zhDate) {
echo $dt->format('Y-m-d'); // 输出:2024-03-15
}
- 注意:
n表示无前导零的月份,j是无前导零的日期,匹配“3月15日”而非“03月15日” - 必须做二次校验(
$dt->format(...) === $zhDate),否则格式错位时可能静默返回错误时间 - 不支持中文数字(如“二〇二四”),需先用映射表转为阿拉伯数字
处理“二〇二四年三月十五日”这类中文数字日期
得先做预处理:把中文数字字符一对一替换为阿拉伯数字,再交给 DateTime::createFromFormat()。
立即学习“PHP免费学习笔记(深入)”;
$map = [
'〇' => '0', '一' => '1', '二' => '2', '三' => '3', '四' => '4',
'五' => '5', '六' => '6', '七' => '7', '八' => '8', '九' => '9',
];
$zhNumDate = '二〇二四年三月十五日';
$converted = str_replace(array_keys($map), array_values($map), $zhNumDate); // → "2024年3月15日"
$dt = DateTime::createFromFormat('Y年n月j日', $converted);
- 注意“〇”是 Unicode U+3007,不是英文字母 O 或数字 0,必须单独列在映射表里
- “十”“二十”“三十”等复合数词需要额外规则(如“十五”→“15”),简单替换不覆盖;真实场景建议用专用库如
overtrue/pinyin或正则分段处理 - 月份和日期里的“三月”“十五日”仍需靠
createFromFormat()解析汉字单位,“三”本身不用转——只有年份部分常用中文数字
真正麻烦的从来不是“有没有函数”,而是中文日期没有统一规范:用户可能输“2024年03月15日”“二零二四.三.十五”“三月十五号2024年”……预处理逻辑得按实际输入来源定,别指望一个正则或一个函数通吃。











