用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

php 排除周末与节假日程序实例代码

时间:2015-01-23  来源:西部数据  作者:西部数据
  1. date_default_timezone_set('prc'); 
  2. /** 
  3. * 求取从某日起经过一定天数后的日期, 
  4. * 排除周六周日和节假日 
  5. * @param $start       开始日期 
  6. * @param $offset      经过天数 
  7. * @param $exception 例外的节假日 
  8. * @param $allow       允许的日期(预留参数) 
  9. * @return//开源代码phpfensi.com 
  10. *  examples:输入(2010-06-25,5,''),得到2010-07-02 
  11. */ 
  12. function getendday( $start='now'$offset=0, $exception=''$allow='' ){ 
  13.     //先计算不排除周六周日及节假日的结果 
  14.     $starttime = strtotime($start); 
  15.     $endtime = $starttime + $offset * 24 * 3600; 
  16.     $end = date('y-m-d'$endtime); 
  17.     //然后计算周六周日引起的偏移 
  18.     $weekday = date('n'$starttime);//得到星期值:1-7 
  19.     $remain = $offset % 7; 
  20.     $newoffset = 2 * ($offset - $remain) / 7;//每一周需重新计算两天 
  21.     if$remain > 0 ){//周余凑整 
  22.         $tmp = $weekday + $remain
  23.         if$tmp >= 7 ){ 
  24.             $newoffset += 2; 
  25.         }else if$tmp == 6 ){ 
  26.             $newoffset += 1; 
  27.         } 
  28.         //考虑当前为周六周日的情况 
  29.         if$weekday == 6 ){ 
  30.             $newoffset -= 1; 
  31.         }else if$weekday == 7 ){ 
  32.             $newoffset -= 2; 
  33.         } 
  34.     } 
  35.     //再计算节假日引起的偏移 
  36.     ifis_array($exception) ){//多个节假日 
  37.         foreach ($exception as $day){ 
  38.             $tmp_time = strtotime($day); 
  39.             if$tmp_time>$starttime && $tmp_time<=$endtime ){//在范围(a,b]内 
  40.                 $weekday_t = date('n'$tmp_time); 
  41.                 if($weekday_t <= 5){//防止节假日与周末重复 
  42.                     $newoffset += 1; 
  43.                 } 
  44.             } 
  45.         } 
  46.     }else{//单个节假日 
  47.         if$exception!='' ){ 
  48.             $tmp_time = strtotime($exception); 
  49.             if$tmp_time>$starttime && $tmp_time<=$endtime ){ 
  50.                 $weekday_t = date('n'$tmp_time); 
  51.                 if($weekday_t <= 5){ 
  52.                     $newoffset += 1; 
  53.                 } 
  54.             } 
  55.         } 
  56.          
  57.     } 
  58.     //根据偏移天数,递归做等价运算111cn.net 
  59.     if($newoffset > 0){ 
  60.         #echo "[{$start} -> {$offset}] = [{$end} -> {$newoffset}]"."<br /> "
  61.         return getendday($end,$newoffset,$exception,$allow); 
  62.     }else
  63.         return $end
  64.     } 
  65. /** 
  66. * 暴力循环方法 
  67. */ 
  68. function getendday2( $start='now'$offset=0, $exception=''$allow='' ){ 
  69.     $starttime = strtotime($start); 
  70.     $tmptime = $starttime + 24*3600; 
  71.      
  72.     while$offset > 0 ){ 
  73.         $weekday = date('n'$tmptime); 
  74.         $tmpday = date('y-m-d'$tmptime); 
  75.         $bfd = false;//是否节假日 
  76.         if(is_array($exception)){ 
  77.             $bfd = in_array($tmpday,$exception); 
  78.         }else
  79.             $bfd = ($exception==$tmpday); 
  80.         } 
  81.         if$weekday<=5 && !$bfd){//不是周末和节假日 
  82.             $offset--; 
  83.             #echo "tmpday={$tmpday}"."<br />"
  84.         } 
  85.         $tmptime += 24*3600; 
  86.     } 
  87.      
  88.     return $tmpday
  89. $exception = array
  90.     '2010-01-01','2010-01-02','2010-01-03'
  91.     '2010-04-03','2010-04-04','2010-04-05'
  92.     '2010-05-01','2010-05-02','2010-05-03'
  93.     '2010-06-14','2010-06-15','2010-06-16'
  94.     '2010-09-22','2010-09-23','2010-09-24'
  95.     '2010-10-01','2010-10-02','2010-10-03','2010-10-04'
  96.     '2010-10-05','2010-10-06','2010-10-07'
  97.      
  98. ); 
  99. //echo getendday('2010-08-27',3,''); 
  100. //echo getendday('2010-06-25',15,'2010-07-07'); 
  101. $t1 = microtime(); 
  102. echo getendday('2010-05-12',66,$exception)."<br />"
  103. $t2 = microtime();echo "use ".($t2-$t1)." s <br />"
  104. echo getendday2('2010-05-12',66,$exception)."<br />"
  105. $t3 = microtime();echo "use ".($t3-$t2)." s <br />"
来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
栏目更新
栏目热门