如何列出两个date之间的所有月份

我试图列出两个date之间的所有月份。

例如; 开始date是: 2010-12-02和上次date是: 2012-05-06

我想列举这样的事情:

 2010-12 2011-01 2011-02 2011-03 2011-04 . . . 2012-04 2012-05 

这是我所尝试过的,它根本不起作用:

  $year_min = 2010; $year_max = 2012; $month_min = 12; $month_max = 5; for($y=$year_min; $y<=$year_max; $y++) { for($m=$month_min; $m<=$month_max; $m++) { $period[] = $y.$m; } } 

PHP 5.3

 $start = new DateTime('2010-12-02'); $start->modify('first day of this month'); $end = new DateTime('2012-05-06'); $end->modify('first day of next month'); $interval = DateInterval::createFromDateString('1 month'); $period = new DatePeriod($start, $interval, $end); foreach ($period as $dt) { echo $dt->format("Ym") . "<br>\n"; } 

看到它的行动

PHP 5.4或更新版本

 $start = (new DateTime('2010-12-02'))->modify('first day of this month'); $end = (new DateTime('2012-05-06'))->modify('first day of next month'); $interval = DateInterval::createFromDateString('1 month'); $period = new DatePeriod($start, $interval, $end); foreach ($period as $dt) { echo $dt->format("Ym") . "<br>\n"; } 

我们将开始和结束date修改为本月的第一天的部分很重要。 如果我们不这样做,并且当天高于二月份的最后一天(即非闰年28岁,闰年29岁),则会跳过2月份。

你必须在同一年的两个月和不同年份的两个月之间做出区别。

 $year_min = substr($row['contractStart'], 0, 4); $year_max = substr($row['contractEnd'], 0, 4); $month_min = substr($row['contractStart'], 5, 2); $month_min = substr($row['contractEnd'], 5, 2); $period = array(); try { if ($year_min > $year_max) throw new Exception(); else if ($year_min == $year_max) if ($month_min > $month_max) throw new Exception(); for ($month = $month_min; $month <= $month_max; $month++) { $period[] = $month . '-' . $year; } else { for ($month = $month_min; $month <= 12; $month++) { $period[] = $month . '-' . $year_min; } for ($year = $year_min + 1; $year < $year_max; $year++) { for ($month = $month_min; $month <= $month_max; $month++) { $period[] = $month . '-' . $year; } } for ($month = 1; $month <= $month_max; $month++) { $period[] = $month . '-' . $year_max; } } implode("<br />\r\n", $period); } catch (Exception $e) { echo 'Start date occures after end date.' } 

这是困难的方式。 现在有一个快速简单的方法,我已经给出了一个答案,我build议你select。

  function getMonthsInRange($startDate, $endDate) { $months = array(); while (strtotime($startDate) <= strtotime($endDate)) { $months[] = array('year' => date('Y', strtotime($startDate)), 'month' => date('m', strtotime($startDate)), ); $startDate = date('d M Y', strtotime($startDate. '+ 1 month')); } return $months; } 

这是我的解决scheme,因为DateTime在我的服务器环境中不可用。

 $a = "2007-01-01"; $b = "2008-02-15"; $i = date("Ym", strtotime($a)); while($i <= date("Ym", strtotime($b))){ echo $i."\n"; if(substr($i, 4, 2) == "12") $i = (date("Y", strtotime($i."01")) + 1)."01"; else $i++; } 

试试看:http: //3v4l.org/BZOmb