[英]How to convert ISO8601 to Date format in php
如何转换( ISO8601 格式): 2014-03-13T09:05:50.240Z
对此( MySQL DATE 格式): 2014-03-13
在 PHP 中?
尝试这个
$date = '2014-03-13T09:05:50.240Z';
$fixed = date('Y-m-d', strtotime($date));
完整的日期函数文档可以在这里找到:http: //php.net/manual/en/function.date.php
PHP 函数“strtotime”除了将时间字符串转换为 unix 时间戳之外什么也不做。
希望我能帮忙:)
Ps:以防万一 strtotime 将返回 0 尝试使用:
$date = '2014-03-13T09:05:50.240Z';
$fixed = date('Y-m-d', strtotime(substr($date,0,10)));
从 PHP 5.2.0
开始,您也可以使用OOP和DateTime()
来实现(当然,如果您更喜欢 OOP):
$now = new DateTime("2014-03-13T09:05:50.240Z");
echo $now->format('Y-m-d'); // MySQL datetime format
没有理由使用低效的时间函数。 最有效的方法是简单地提取前 10 个字符:
substr($date,0,10)
真正编码 ≥10000 年的人可以使用:
substr($date,0,strpos($date,"T"))
只需使用strtotime将 datetime 描述转换为 Unix 时间戳,然后使用Date Formats将五种格式
试试它肯定会为你工作。
$date = '2014-03-13T09:05:50.240Z';
$fixed = date('Y-m-d', strtotime($date));
今天,我发布了一个interitty/utils包,其中处理 ISO-8601 格式以及可能该标准的所有排列。
我希望它也能帮助你。
$dateTimeFactory = new Interitty\Utils\DateTimeFactory();
$dateTime = $dateTimeFactory->createFromIso8601('1989-12-17T12:00:00Z');
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.