定义interval的开始日期



我使用以下行来计算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作为新的开始日期的,所以我不能直接解决这个问题。

相关内容

  • 没有找到相关文章