计算指定工作日后的日期

最近项目中要用到这样一个功能,计算N个工作日之后的日期,现在想到如下方案感觉可以解决问题。

这个说明下,工作日还是按照国家规定的来算的,就是周一到周五、法定假期前后调休需上班的都算作工作日,周六、周日和法定假日则不算工作日,法定假日和调休上班的日期可存在数据库中进行维护。

代码如下,感觉效率不算很高,如有更好的办法,还请高人分享一下。

<?php 
date_default_timezone_set("Asia/Shanghai");//设置好一个时区


$now=mktime(0, 0, 0,8,1,2013);//开始的日期,可以是现在或其他你想要的某一个日期的时间戳,这里设置2013-08-01
$i=10;//要求计数的工作日数量

/*国家法定假日一般可以存储在数据库中进行维护,包括休假的日期,和周末调休上班的日期两类,作为演示对应日期暂时放在数组中*/
$working=array(mktime(0, 0, 0,8,3,2013),mktime(0, 0, 0,8,11,2013));//周末调休上班的日期
$holiday=array(mktime(0, 0, 0,8,8,2013),mktime(0, 0, 0,8,6,2013));//法定假期

$day=date("d",$now);//把当天的日期给一个变量
$w=0;//工作日计数变量
while($w<$i){//当达到要求的工作日数量则停止循环
    $newdate=mktime(0, 0, 0,date("m",$now),++$day,date("Y",$now));//加一天输出新的时间戳
    if(in_array($newdate, $working)){//判断一下,如果属于调休的则工作日计数加一,如果法定假日调休存在数据库中,则这里需要一条查询语句来查询一下
        $w++;
    }else{//如不属于调休的则再进行判断,既不是周六周日,也不是法定假日,则工作日计数再加上一
        if(date("w",$newdate)!=0&&date("w",$newdate)!=6&&!in_array($newdate, $holiday)){
                $w++;
        }
    }
}
    
echo date("Y-m-d",$newdate);//最后得出的时间戳就是要求的10个工作日后的日期了。

?>

 

posted @ 2013-07-31 23:57  qīqíqǐqì  阅读(1108)  评论(0编辑  收藏  举报