【发布时间】:2017-10-01 08:24:07
【问题描述】:
我正在用 PHP 实现一个带有时间戳和基于时间戳计算的值的表(计算对我的问题无关紧要)。
在从夏令时到冬令时(夏令时)的转换中使用 add 方法时,我注意到 PHP 的 DateTime 对象中有一个非常奇怪的行为。
在我的示例中,我将 15 分钟添加到时间戳并打印(使用本地格式、unix utc 时间戳和时间戳偏移以秒为单位):
<?php
date_default_timezone_set('Europe/Vienna');
$offset = new DateInterval("PT15M");
foreach([new DateTime("2016-03-27 01:00:00"),
new DateTime("2016-10-30 01:00:00")] as $dt) {
$lastTs = NULL;
for($j = 0; $j < 12; $j++) {
echo $dt->format('d.M.Y H:i:s P (U)');
if(!is_null($lastTs))
echo ' (+' . ($dt->format('U') - $lastTs) . ')';
$lastTs = $dt->format('U');
echo "\n";
$dt->add($offset);
}
echo "\n";
}
这个小脚本给了我一个这样的表格(注意 30.Oct.2016 02:15 的巨大跳跃):
27.Mar.2016 01:00:00 +01:00 (1459036800)
27.Mar.2016 01:15:00 +01:00 (1459037700) (+900)
27.Mar.2016 01:30:00 +01:00 (1459038600) (+900)
27.Mar.2016 01:45:00 +01:00 (1459039500) (+900)
27.Mar.2016 03:00:00 +02:00 (1459040400) (+900)
27.Mar.2016 03:15:00 +02:00 (1459041300) (+900)
27.Mar.2016 03:30:00 +02:00 (1459042200) (+900)
27.Mar.2016 03:45:00 +02:00 (1459043100) (+900)
27.Mar.2016 04:00:00 +02:00 (1459044000) (+900)
27.Mar.2016 04:15:00 +02:00 (1459044900) (+900)
27.Mar.2016 04:30:00 +02:00 (1459045800) (+900)
27.Mar.2016 04:45:00 +02:00 (1459046700) (+900)
30.Oct.2016 01:00:00 +02:00 (1477782000)
30.Oct.2016 01:15:00 +02:00 (1477782900) (+900)
30.Oct.2016 01:30:00 +02:00 (1477783800) (+900)
30.Oct.2016 01:45:00 +02:00 (1477784700) (+900)
30.Oct.2016 02:00:00 +02:00 (1477785600) (+900)
30.Oct.2016 02:15:00 +01:00 (1477790100) (+4500)
30.Oct.2016 02:30:00 +01:00 (1477791000) (+900)
30.Oct.2016 02:45:00 +01:00 (1477791900) (+900)
30.Oct.2016 03:00:00 +01:00 (1477792800) (+900)
30.Oct.2016 03:15:00 +01:00 (1477793700) (+900)
30.Oct.2016 03:30:00 +01:00 (1477794600) (+900)
30.Oct.2016 03:45:00 +01:00 (1477795500) (+900)
3 月 27 日,一切正常。但是当回到冬天时,有一个巨大的跳跃。我不认为这是 DST 的工作原理。
相反,我真的很想看到这个输出(在记事本中编辑):
30.Oct.2016 01:45:00 +02:00 (1477784700) (+900)
30.Oct.2016 02:00:00 +02:00 (1477785600) (+900)
30.Oct.2016 02:15:00 +02:00 (1477786500) (+900)
30.Oct.2016 02:30:00 +02:00 (1477787400) (+900)
30.Oct.2016 02:45:00 +02:00 (1477788300) (+900)
30.Oct.2016 02:00:00 +01:00 (1477789200) (+900)
30.Oct.2016 02:15:00 +01:00 (1477789200) (+900)
30.Oct.2016 02:30:00 +01:00 (1477791000) (+900)
30.Oct.2016 02:45:00 +01:00 (1477791900) (+900)
30.Oct.2016 03:00:00 +01:00 (1477792800) (+900)
30.Oct.2016 03:15:00 +01:00 (1477793700) (+900)
现在 02:00 出现了 2 次,但偏移量不同(以及正确的 unix 时间戳)。
需要对我的代码进行哪些更改才能获得如上所示的正确结果?
【问题讨论】: