在做统计的时候如果按照周统计 ,需要对某个月的周次信息进行计算,如果本月头一天不是星期一,则向上一个月取周一,本月最后的几天如果不能正好是一周,则忽略。
例如
2019-09月计算出来的结果
2016-08-29---2016-09-04
2016-09-05---2016-09-11
2016-09-12---2016-09-18
2016-09-19---2016-09-25
具体代码实现如下:
<?php
$current_year=2016;
$current_month=9;
$firstday = strtotime($current_year.'-'.$current_month.'-01');
//计算本月头一天的星期一
$monday=$firstday-86400*(date('N',$firstday)-1);//计算第一个周一的日期
//由于每个月只有四周 让 $i 从 1 到 5 增加即可
for ($i=1; $i <= 5; $i++) {
$start=date("Y-m-d",$monday+($i-1)*86400*7);//起始周一
$end=date("Y-m-d",$monday+$i*86399*7);//结束周日
if(date('m',$monday+$i*86399*7)!=$current_month)
{
continue;
}
echo $start.'---'.$end."<br/>";//开始结束放入数组
}
?>