我使用以下行来计算PHP中的4周间隔。它使用一个固定的日期($calStart
)作为计算的基础,并以所选年份($rangeEnd
/$selYear
)的最后一天结束间隔,这到目前为止运行良好。
示例:如果选择的年份是2015,则此处范围内的第一个日期应该是2015-01-16作为所选年份的第一个间隔日期。
这里有人能告诉我如何设置这一点,使$rangeDays
仅从所选年份的第一个间隔日期开始,而不是返回自$calStart
日期以来的所有间隔(这是它目前所做的)?
$calStart = new DateTime('2014-01-17');
$interval = DateInterval::createFromDateString('4 weeks');
$rangeEnd = new DateTime($selYear . '-12-31');
$rangeDays = new DatePeriod($calStart, $interval, $rangeEnd);
非常感谢你的帮助,蒂姆。 你可以试试:
$calStart = new DateTime('2014-01-17');
$calYear = $calStart->format('Y');
if ($selYear !== $calYear) {
$day = (int) $calStart->format('z') + date('z', mktime(0,0,0,12,31,$calYear)) * ($selYear - $calYear);
$calStart->setDate($selYear, 1, $day % 28);
}
编辑:这个更复杂:
$calStart = new DateTime('2014-01-17');
$calYear = (int) $calStart->format('Y');
if ($selYear !== $calYear) {
$days = (int) $calStart->format('z') + 1; // get day in a year. +1 is because it starts with 0
for ($i = $calYear; $i < $selYear; $i++) {
$days -= (date('z', mktime(0,0,0,12,31,$i)) + 1) % 28; // remove from start day a modulo of 28 days, every year the date is lower
}
if ($days < 0) {
$days += 28; // if we will finish with value under 0, just add 4 weeks
}
$calStart->setDate($selYear, 1, $days);
}
如果你想让$calStart
和$rangeEnd
在同一年开始,这应该为你做:
$calStart = new DateTime('2014-01-17');
if ($selYear !== $calStart->format('Y')) {
$calStart->setDate($selYear , $calStart->format('n'), $calStart->format('j'));
}
$interval = DateInterval::createFromDateString('4 weeks');
$rangeEnd = new DateTime($selYear . '-12-31');
$rangeDays = new DatePeriod($calStart, $interval, $rangeEnd);
我不确定你是如何得到2015-01-16
作为新的开始日期的,所以我不能直接解决这个问题。