我正在尝试获取一个日期和接下来的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。我无法弄清楚为什么?
我做错了什么?
谢谢!
答案 0 :(得分:7)
由于daylight saving time switch,您的日期相同。添加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)
);
}
答案 1 :(得分: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);
答案 2 :(得分:4)
我建议像:
for($i=1;$i<=14;$i++){
echo("$i day(s) away: ".date("m/d/Y",strtotime("+$i days")));
}