0

我有一个 ajax 数据对象,它带有$startDatewhich isNov 12, 2013和 a $endDatewhich is January 31, 2014,我想创建一个如下所示的数组:

array(2013-11-12, 2013-11-13, 2013-11-14, ... , 2014-01-31);

我尝试这样做的方式是:

    while($startDate < $endDate){
       $day = gmdate('Y-m-d', strtotime('+1 day', strtoTime($data->data['startDate'])));
       $daysOfTheWeek[] = $day;
    }

但是脚本在 30 秒后超时。所以我想知道这样做的正确方法是什么。

4

2 回答 2

1
date_default_timezone_set('UTC');
$date_from = 'Nov 12, 2013';
$date_to = 'January 31, 2014';
$date_range = array_map(function ($date) {
        return $date->format('Y-m-d');
    }, iterator_to_array(
        new DatePeriod(new DateTime($date_from),
                       DateInterval::createFromDateString('+1 day'),
                       (new DateTime($date_to))->modify('+1 day'))));
var_dump($date_range);

演示:https ://eval.in/68133

于 2013-11-14T17:43:34.573 回答
1
<?php
  $dates=array();
  $start=strtotime("Nov 12, 2013");
  $end=strtotime("January 31, 2014");
  while($start <= $end)
  {
    $dates[]=date("Y-m-d",$start);
    $start=strtotime("+1 day",$start);
  }
  print_r($dates);
?>

小提琴

于 2013-11-14T17:38:57.067 回答