我正在从数据库中检索格式为 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小时。
您输入的日期时间采用 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 时区的日期时间。如果您想更改时区,只需致电->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
)
*/
附注因为输入2013-09-15 08:45:00
是标准日期时间格式,您不需要使用DateTime::createFromFormat
.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)