如何在php中将ISO8601转换为日期格式
Posted
技术标签:
【中文标题】如何在php中将ISO8601转换为日期格式【英文标题】:How to convert ISO8601 to Date format in php 【发布时间】:2014-04-18 01:22:04 【问题描述】:如何转换(ISO8601 格式): 2014-03-13T09:05:50.240Z
至此(mysql DATE 格式): 2014-03-13
在 php 中?
【问题讨论】:
好吧,似乎抓住T
之前的输入部分会给你想要的结果。您是否尝试过这样做,例如使用substr
?
Using PHP: How convert an ISO8601 date to a different format的可能重复
【参考方案1】:
没有理由使用低效的时间函数。最有效的方法是简单地提取前 10 个字符:
substr($date,0,10)
真正编码年份≥10000 的人可以使用:
substr($date,0,strpos($date,"T"))
【讨论】:
那将在 10000 年打破 添加了 10000 年解决方案 ;)【参考方案2】:对于那些使用 Carbon(php 库)的人,parse()
工作得很好:
Carbon::parse($date)
https://carbon.nesbot.com/docs/
【讨论】:
【参考方案3】:从 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
【讨论】:
【参考方案4】:试试这个
$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 时间戳之外什么都不做。
希望我能帮上忙:)
附注: 以防万一 strtotime 将返回 0 尝试使用:
$date = '2014-03-13T09:05:50.240Z';
$fixed = date('Y-m-d', strtotime(substr($date,0,10)));
【讨论】:
非常感谢...效果很棒!如果返回 0,您使用date('Y-m-d', strtotime(substr($date,0,10)))
的最后一条说明是完美的。那对我来说效果很好!它对我帮助很大!谢谢... :)【参考方案5】:
使用 strtotime 将日期时间描述转换为 Unix 时间戳,然后使用 Date Formats 将五种格式转换
试试吧,它肯定对你有用。
$date = '2014-03-13T09:05:50.240Z';
$fixed = date('Y-m-d', strtotime($date));
【讨论】:
谢谢米图尔。这似乎可行,但如果格式与我原来的问题不同,例如:Thu Mar 13 2014 17:21:17 GMT+0530 (India Standard Time)
,在转换后,$fixed
值将其输出为 1970-01-01。那么这种格式有不同的方法吗?
实际上@ThatMSG 建议使用date('Y-m-d', strtotime(substr($date,0,10)))
有效!。感谢 Mitul 的支持!
@blackops_programmer :无论您发送什么格式,它都可以正常工作。check your example.以上是关于如何在php中将ISO8601转换为日期格式的主要内容,如果未能解决你的问题,请参考以下文章
如何在 Pandas 数据框中将日期转换为 ISO-8601 DateTime 格式
如何配置 web api 的 json 序列化器将日期时间转换为 ISO 8601 格式?