目的是为了解决前段时间一个关于在年内的某周进行验证,并计算初始的每周的周一及周末的算法,发现一些问题,特记录,代码如下:
<?php
$year=date("Y");
$fdate="2022-1-1";
$year=intval(date("Y",strtotime($fdate)));
$weekly=intval(date("W",strtotime($fdate)));
$month=intval(date("m",strtotime($fdate)));
if($month==12&&$weekly<10){
$year++;
}
if($month==1&&$weekly>50){
$year--;
}
echo $year." ".$weekly;
echo "-----------------------------<BR>";
echo "the bad show:<BR>";
for($i=1;$i<53;$i++){
$temp_flow_year=date("Y-m-d",strtotime($year . 'W0' . $i));
echo $year . 'W0' . $i." 'year is:".$temp_flow_year."<BR>";
}
echo "-----------------------------<BR>";
echo "the right show:<BR>";
for($i=1;$i<54;$i++){
$temp_flow_year=date("Y-m-d",strtotime($year . 'W' . (($i<10)?"0".$i:$i)));
echo $year . 'W' . (($i<10)?"0".$i:$i)." 'year is:".$temp_flow_year."<BR>";
}
主要想展示的是,在每年的年初几天里面,有时间会导致计算取到的年与周所在的年不一致,导致异常发生。 此处通过两个判断,如果月份为12月,但计算出来的周小于10,则年加1。 如果月份为1,但计算出的周大于50,则年减一,进行周的修正。
同时,strtotime(“2021W01”)此处是一个坑。 关于这个2021W01格式上,目前暂未找到非常官方的资料,经实验后发现,此格式允许两种: 1、W后有两位,即2021W01格式,此情况下,会计算周一的日期出来,同时W后必须为两位,如果为1位,则数据会异常,格式会算到1970-01-01。 2、W后有三位,即2021W011格式,此情况下,默认W011,最后一位1可以取值范围为0-7,分别0对应上周的周日、1对应周一以此类推,7代表本周的周日,此情况下,可依据不同的计算习惯,确定本周的第一天及算法。 特此备注,以防再次被坑。 php版本为8.0.8
|