3

我正在尝试获取一个日期数组以及接下来的 13 个日期,以获得从给定日期开始的 14 天时间表。

这是我的功能:

$time = strtotime($s_row['schedule_start_date']); // 20091030
$day = 60*60*24;
for($i = 0; $i<14; $i++)
{
    $the_time = $time+($day*$i);
    $date = date('Y-m-d',$the_time);
    array_push($dates,$date);
}

但它似乎在重复月份切换的日期..

这就是我得到的:

2009-10-30|2009-10-31|2009-11-01|2009-11-01|2009-11-02|2009-11-03|2009-11-04|2009-11-05|2009- 11-06|2009-11-07|2009-11-08|2009-11-09|2009-11-10|2009-11-11

请注意,重复了 2009-11-01。我不知道为什么?

我究竟做错了什么?

谢谢!!

4

3 回答 3

7

由于夏令时切换,您有相同的日期。24*60*60添加秒数来查找第二天是不安全的,因为一年中的 2 天中有更多/更少的秒数。当您从夏季时间切换到冬季时间时,您将每天增加 1 小时。所以25*60*60那天会是几秒钟,这就是为什么它没有在你的代码中切换。

您可以通过 进行计算mktime()。例如:

## calculate seconds from epoch start for tomorrow
$tomorrow_epoch = mktime(0, 0, 0, date("m"), date("d")+1, date("Y"));
## format result in the way you need
$tomorrow_date = date("M-d-Y", $tomorrow_epoch);

或您的代码的完整版本:

$dates = array();
$now_year = date("Y");
$now_month = date("m");
$now_day = date("d");
for($i = 0; $i < 14; $i++) {
    $next_day_epoch = mktime(0, 0, 0, $now_month, $now_day + $i, $now_year);
    array_push(
        $dates,
        date("Y-m-d", $next_day_epoch)
    );
}
于 2009-10-28T18:11:12.390 回答
7

我会使用 strtotime

$start = strtotime($s_row['schedule_start_date']);
$dates=array();
for($i = 1; $i<=14; $i++)
{
    array_push($dates,date('Y-m-d', strtotime("+$i day", $start)));
}
print_r($dates);
于 2009-10-28T18:19:03.450 回答
4

我推荐类似的东西:

for($i=1;$i<=14;$i++){
     echo("$i day(s) away: ".date("m/d/Y",strtotime("+$i days")));
}
于 2009-10-28T18:19:26.383 回答