使用PHP跳过周末计算基于startdate和value的日期

时间:2012-08-14 07:53:28

标签: php date skip weekend

我有一个开始日期,让我们说这是$startDate = 2012-08-01;我有一个存储INT值的变量,假设这是$value = 10;

我想计算从startdate + 10天到周末的日期。

使用上述值,结果为2012-08-15

如何做到这一点?

4 个答案:

答案 0 :(得分:4)

这远非有效,但是当它可读时谁会关心它? :)

<?php
function calculateNextDate($startDate, $days)
{
        $dateTime = new DateTime($startDate);

        while($days) {
            $dateTime->add(new DateInterval('P1D'));    

            if ($dateTime->format('N') < 6) {
                $days--;
            }
        }

        return $dateTime->format('Y-m-d');
}

echo calculateNextDate('2012-08-01', 10); // return 2012-08-15

DEMO

应该很容易理解会发生什么。首先,我们使用用户提供的日期创建一个新的DateTime对象。在那之后,我们将遍历我们想要添加到日期的日子。当我们在周末点击一天时,我们不会从我们想要添加到日期的日期中减去一天。

答案 1 :(得分:0)

你可以使用php的strtotime功能+ n天/小时等..,

并且为了排除周末,请看这里: 32 hours ago excluding weekends with php

答案 2 :(得分:0)

试试这个

<?php
function businessdays($begin, $end) {
    $rbegin = is_string($begin) ? strtotime(strval($begin)) : $begin;
    $rend = is_string($end) ? strtotime(strval($end)) : $end;
    if ($rbegin < 0 || $rend < 0)
        return 0;

    $begin = workday($rbegin, TRUE);
    $end = workday($rend, FALSE);

    if ($end < $begin) {
        $end = $begin;
        $begin = $end;
    }

    $difftime = $end - $begin;
    $diffdays = floor($difftime / (24 * 60 * 60)) + 1;

    if ($diffdays < 7) {
        $abegin = getdate($rbegin);
        $aend = getdate($rend);
        if ($diffdays == 1 && ($astart['wday'] == 0 || $astart['wday'] == 6) && ($aend['wday'] == 0 || $aend['wday'] == 6))
            return 0;
        $abegin = getdate($begin);
        $aend = getdate($end);
        $weekends = ($aend['wday'] < $abegin['wday']) ? 1 : 0;
    } else
        $weekends = floor($diffdays / 7);
    return $diffdays - ($weekends * 2);
}

function workday($date, $begindate = TRUE) {
    $adate = getdate($date);
    $day = 24 * 60 * 60;
    if ($adate['wday'] == 0) // Sunday
        $date += $begindate ? $day : -($day * 2);
    return $date;
}

$def_date="";//define your date here
$addDay='5 days';//no of previous days  
date_add($date, date_interval_create_from_date_string($addDay));
echo businessdays($date, $def_date); //date prior to another date 
?>

PHP.net修改

答案 3 :(得分:-2)

如果你只想加上日期+10,你可能会考虑这个:

日期(“Y-m-d”,strtotime(“+ 10天”));