php中输出24小时制时间应使用date('h:i:s'),h表示00–23,h为12小时制;需配合正确时区设置(如date_default_timezone_set('asia/shanghai')),避免格式符与时区混淆。

PHP中date()函数怎么输出24小时制时间
默认用date('h:i:s')会显示12小时制(带AM/PM),想显示24小时制,必须换格式符:H代表00–23,h才是01–12。常见错误是抄到h就以为完事了,结果下午3点还显示03:00:00。
正确写法示例:
echo date('H:i:s'); // 输出 15:30:45
-
H:24小时制,两位数字,不足补零(00–23) -
G:24小时制,无前导零(0–23),适合拼接URL或日志前缀 -
h+a或A是12小时制组合,和24小时制无关,别混用 - 时区没设准的话,
date()返回的可能是服务器本地时间,不是你预期的北京时间
strtotime()解析字符串时为什么有时变成12小时制
strtotime()本身不决定显示格式,它只返回时间戳;问题出在后续用date()格式化时用了h。更隐蔽的坑是:传入类似"3:30pm"这种字符串,strtotime()能正确转成15:30的时间戳,但如果你用date('h:i:s', $ts)输出,还是会得03:30:00——这不是解析错了,是格式符选错了。
- 输入字符串带
am/pm,strtotime()能识别,无需额外处理 - 输入纯数字如
"15:30",直接走24小时逻辑,strtotime()也认 - 真正要检查的是你
date()里写的格式符,不是strtotime()的问题 - 避免用
date('Y-m-d h:i:s')存数据库时间字段,容易引发时区+制式双重混淆
DateTime类设置24小时制要注意时区和格式化分离
DateTime对象内部存的是UTC时间戳,format()只是渲染方式。很多人调$dt->setTimezone(new DateTimeZone('Asia/Shanghai'))后,以为“设置了时间”,其实只是改了显示基准,真正影响输出的还是format()里的格式符。
立即学习“PHP免费学习笔记(深入)”;
示例:
$dt = new DateTime('2024-05-20 15:30:00', new DateTimeZone('UTC'));
$dt->setTimezone(new DateTimeZone('Asia/Shanghai')); // 转成东八区时间
echo $dt->format('H:i:s'); // 输出 23:30:00(UTC 15:30 → 北京时间 23:30)
-
format('H:i:s')才决定是否24小时制,setTimezone()只负责偏移换算 - 构造时没传
DateTimeZone,默认用date_default_timezone_get(),建议显式设好,比如date_default_timezone_set('Asia/Shanghai') - 用
format('g:i A')这类会强制切回12小时制,和对象时区无关
MySQL存时间字段后PHP读出来怎么保持24小时制显示
MySQL的TIMESTAMP和DATETIME字段本身不存“制式”概念,它们存的是字面值。PHP从PDO或mysqli取出来是字符串(如"2024-05-20 15:30:00"),这时直接date('H:i:s', strtotime($row['created_at']))是安全的;但如果字段是TIME类型且值为"15:30:00",strtotime()仍能正确解析。
- 别用
date('h:i:s', ...)去格式化从数据库读出的时间字符串,除非你明确想转12小时制 - 如果数据库里存的是Unix时间戳整数,直接
date('H:i:s', $row['ts'])即可,H依然生效 - ORM如Eloquent可能自动转成
DateTime对象,此时调format('H:i:s')才有效,__toString()默认用Y-m-d H:i:s,放心
H不够,date_default_timezone_set()没对,或者数据库时区和PHP不一致,时间照样错得离谱。










