日期时间转换:“在数据库中找不到时区”

时间:2013-06-15 15:19:19

标签: 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;
}

Wich给了我

 "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使用我用来转换它的完全相同的格式创建的?

1 个答案:

答案 0 :(得分:9)

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

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