微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PHP strtotime转换在某些日期时间不起作用

我正在尝试从Web服务结果集中对我的datetime条目执行strtotime(绝不为null).

在循环和cnoverting时,我发现许多都无法使用strtotime进行转换.问题是什么?有效的格式与无效的格式之间没有区别.

1431109502 - 08-05-2015 13:25:02
- 06-15-2015 12:05:32 -- Didn't work (any that start with - didn't convert)
- 06-25-2015 11:30:30
- 06-15-2015 10:58:56
- 06-27-2015 20:33:31
- 06-28-2015 00:13:37
1431054141 - 07-05-2015 22:02:21
- 07-17-2015 07:23:57
- 07-22-2015 02:30:24
1431090998 - 08-05-2015 08:16:38
1433774646 - 08-06-2015 09:44:06

编辑:这是我用来尝试获得100%转化的一些代码.

$t = date_create_from_Format( 'd-m-Y H:i:s', trim($arrCurrentAlarms[$i]["DateTime"]) );
$sqldt = $t->format('Y-m-d H:i:s');

提供给我的输入始终采用以下格式:06-25-2015 11:30:30
(年月日hr min sec)

解决方法:

那是因为strtotime猜错了您的日期:

date('r', strtotime('08-05-2015 13:25:02')) -> Fri, 08 May 2015 13:25:02 -0500
date('r', strtotime('06-25-2015 11:30:30')) -> Wed, 31 Dec 1969 18:00:00 -0600

现在注意第一个值是5月8日:strtotime正在考虑您的日期为dd-mm-yyyy,而您确实有mm-dd-yyyy.

请注意第二个日期如何显示为1969年12月-这就是整数0(又称布尔FALSE)作为我特定时区中的日期如何显示的方式.因为失败,所以日历中没有月份25.

由于猜测错误,因此您必须改用date_create_from_format(),然后告诉PHP您的日期采用的格式.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐