如何在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 开始,您也可以使用 OOPDateTime() 来实现(当然,如果您更喜欢 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 格式

如何将 Excel 中的日期转换为 ISO 8601 格式

如何使用 PHP 将日期显示为 iso 8601 格式

如何配置 web api 的 json 序列化器将日期时间转换为 ISO 8601 格式?

一种将当前日期时间转换为 ISO 8601 格式的优雅方法 [重复]

在 Ruby 中将 UTC 时间戳转换为 ISO 8601