php - 日期时间转换 : "The timezone could not be found in the database"

标签 php datetime

我正在尝试转换从 API 接收到的 DateTime。

这是他们生成日期时间字符串的方式:

public static function formatDate($date) {
    $format = "Y-m-d\TH:i:sP";
    if ($date instanceof DateTime) {
        $d = $date->format($format);
    } elseif (is_numeric($date)) {
        $d = date($format, $date);
    } else {
        $d = (String) "$date";
    }
    return $d;
}

这给了我

 "2013-06-14T04:00:36.000-03:00"

这就是我将其转换回来的方法:

try 
{ 
   $date = Carbon\Carbon::createFromFormat("Y-m-d\TH:i:sP", "2013-06-14T04:00:36-03:00");

   echo "<pre>".var_dump($date)."</pre>";

   $date = DateTime::createFromFormat("Y-m-d\TH:i:sP", "2013-06-14T04:00:36.000-03:00");

   echo "<pre>".var_dump($date)."</pre>";

   $date = Carbon\Carbon::createFromFormat("Y-m-d\TH:i:sP", "2013-06-14T04:00:36.000-03:00"); /// raise exception

   echo "<pre>".var_dump($date)."</pre>";
} 
catch(InvalidArgumentException $x) 
{ 
    echo $x->getMessage(); 
}

DateTime 类只给我一个 null,没有错误,但是从 DateTime 扩展的 Carbon (https://github.com/briannesbitt/Carbon) 告诉我发生了什么,这是输出:

object(Carbon\Carbon)#181 (3) { ["date"]=> string(19) "2013-06-14 04:00:36" ["timezone_type"]=> int(1) ["timezone"]=> string(6) "-03:00" }

bool(false)

The timezone could not be found in the database

因此,只需从有效的日期时间中删除“.000”,但为什么,如果它是由 PHP 使用我用来将其转换回来的完全相同的格式创建的呢?

最佳答案

格式不一样。您收到的字符串的正确格式是:

$format = "Y-m-d\TH:i:s.uP";

关于php - 日期时间转换 : "The timezone could not be found in the database",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17125092/

相关文章:

c# - c#中的日期计算

php编码使用php将表单提交到服务器

mysql - 如何在mysql中选择24小时记录每一小时?

mysql - 从 MySQL 中的日期时间间隔中提取统计信息

php - 如何使用php删除html中的回车符?

c# - 将日期从波斯语转换为公历

python - 将 Pandas 中的列解析为时间

php - Preg 用于检查它发生了多少次

php - 如何获取magento表名

javascript - 将自定义颜色添加到 w2ui 单元格 [Grid]