如何获取本周星期一的日期?(涉及IT技术)

4
$start_date = '2015-09-21';
$end_Date = '2016-09-21';



    function getStartAndEndDate($start_date, $end_Date ){
        $date1 = new DateTime($start_date);
        $date2 = new DateTime($end_Date);
        $interval = $date1->diff($date2);
        
        
        $weeks = floor(($interval->days) / 7);
        $date_differences = array();
        for($i = 1; $i <= $weeks; $i++){    
            $date1->add(new DateInterval('P4D'));
            $s_time = strtotime($start_date);
            $week_number = date('W', $s_time); 
            $date_differences[] = $start_date." - ".$date1->format('Y-m-d')."<br>";
            $date1->add(new DateInterval('P3D'));
            $start_date = $date1->format('Y-m-d');
            }
            
            return $date_differences;
        }

函数的输出结果为:

    [0] => 2015-09-1 @@ 2015-09-05
    [1] => 2015-09-08 @@ 2015-09-12
    [2] => 2015-09-15 @@ 2015-09-19
    [3] => 2015-09-22 @@ 2015-09-26
    [4] => 2015-09-29 @@ 2015-10-03
    [5] => 2015-10-06 @@ 2015-10-10
    [6] => 2015-10-13 @@ 2015-10-17
    [7] => 2015-10-20 @@ 2015-10-24
    [8] => 2015-10-27 @@ 2015-10-31
    [9] => 2015-11-03 @@ 2015-11-07

在这个函数中,当我给出开始日期和结束日期时,它会返回所有周的开始日期和结束日期。但是问题在于,当我给定一个不是星期一的日期时,它仅仅添加四天,使得一周变成(从星期二到星期六)。
我想要的是,如果有人输入的日期不是星期一,它应该从星期一开始计算一周。例如:
$start_date = '2015-09-21';
$end_Date = '2016-09-21';

它返回这样的输出:

[0] => 2015-08-31 @@ 2015-09-04
[1] => 2015-09-07 @@ 2015-09-11
[2] => 2015-09-14 @@ 2015-09-18
[3] => 2015-09-21 @@ 2015-09-25
2个回答

0

使用DateTime识别日期是星期几并计算出周一:

$s = new DateTime('2016-09-23');
$s->modify('-' . $s->format('N')+1 . 'days');
//2016-09-19
echo $s->format('Y-m-d');

-1
$date = new DateTime('your date');

$date->modify('-' . $date->format('N')+1 . 'days');

并以任何您想要的格式打印日期 :)


为什么要抄袭我的答案? - danopz

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接