我正在从数据库中检索2013-09-15 08:45:00格式的日期,该日期以UTC格式设置,我需要将其更改为另一个动态时区(基于用户)
到目前为止我已经
了$datetime = $row->field_data_field_performance_times_field_performance_times_v;
$eventDate = DateTime::createFromFormat('Y-m-d H:i:s', $datetime, new DateTimeZone($user->timezone));
$performance_time = date_format($eventDate, 'l, j F, Y, H:i');
但它并没有改变时区。有什么想法有什么不对吗?在我的情况下它应该是+2小时。
答案 0 :(得分:9)
您的输入日期时间是UTC,而不是用户的时区。首先,您必须以UTC格式创建日期时间对象,然后将时区设置/更改为用户:
$dt = new DateTime('2013-09-15 08:45:00', new DateTimeZone('UTC'));
print_r($dt);
/*
DateTime Object
(
[date] => 2013-09-15 08:45:00
[timezone_type] => 3
[timezone] => UTC
)
*/
现在您有UTC时区的日期时间。如果您想更改时区,只需在DateTime对象上调用->setTimezone()
:
$dt->setTimezone(new DateTimeZone('Europe/Berlin'));
print_r($dt);
/*
DateTime Object
(
[date] => 2013-09-15 10:45:00
[timezone_type] => 3
[timezone] => Europe/Berlin
)
*/
P.S。因为输入2013-09-15 08:45:00
采用标准日期时间格式,所以您无需使用DateTime::createFromFormat
。