时间:2021-07-01 10:21:17 帮助过:17人阅读
计算方法:
<?php/**
* 计算指定日期的一周开始及结束日期
* @param DateTime $date 日期
* @param Int $start 周几作为一周的开始 1-6为周一~周六,0为周日,默认0
* @retrun Array
*/function getWeekRange($date, $start=0){ // 将日期转时间戳
$dt = new DateTime($date); $timestamp = $dt->format('U'); // 获取日期是周几
$day = (new DateTime('@'.$timestamp))->format('w'); // 计算开始日期
if($day>=$start){ $startdate_timestamp = mktime(0,0,0,date('m',$timestamp),date('d',$timestamp)-($day-$start),date('Y',$timestamp));
}elseif($day<$start){ $startdate_timestamp = mktime(0,0,0,date('m',$timestamp),date('d',$timestamp)-7+$start-$day,date('Y',$timestamp));
} // 结束日期=开始日期+6
$enddate_timestamp = mktime(0,0,0,date('m',$startdate_timestamp),date('d',$startdate_timestamp)+6,date('Y',$startdate_timestamp)); $startdate = (new DateTime('@'.$startdate_timestamp))->format('Y-m-d'); $enddate = (new DateTime('@'.$enddate_timestamp))->format('Y-m-d'); return array($startdate, $enddate);
}?>实例:测试分别以周一至周日为开始计算日期的一周开始及结束时间
<?php$date = '2016-04-27';for($start=0; $start<=6; $start++){ list($startdate, $enddate) = getWeekRange($date, $start); echo 'date:'.$date.' week start:'.$start.' range:'.$startdate.', '.$enddate.'<br>';
}?>输出:
date:2016-04-27 week start:0 range:2016-04-24, 2016-04-30date:2016-04-27 week start:1 range:2016-04-25, 2016-05-01date:2016-04-27 week start:2 range:2016-04-26, 2016-05-02date:2016-04-27 week start:3 range:2016-04-27, 2016-05-03date:2016-04-27 week start:4 range:2016-04-21, 2016-04-27date:2016-04-27 week start:5 range:2016-04-22, 2016-04-28date:2016-04-27 week start:6 range:2016-04-23, 2016-04-29
本文讲解了php获取指定日期的相关内容,更多相关知识请关注Gxl网。
相关推荐:
详解PHP生成唯一RequestID类
如何通过MySQL查看数据库表容量大小
关于php str_getcsv把字符串解析为数组的使用方法的讲解
以上就是讲解php获取指定日期的相关内容的详细内容,更多请关注Gxl网其它相关文章!