PHP-如何在日期数组中查找缺失的日期并填补缺失的空白

时间:2020-02-06 09:01:22

标签: php-7.2 mysql-5.7

您好,stackoverflow的伟大社区。我有一个我无法解决的问题。我需要找到X个日期之间缺少的日期。谢谢。

从数据库获取数据

$stmt=$db_con->prepare("SELECT date_from, date_to, country FROM work WHERE worker_id=xx");

while($row = $stmt->fetch()) { <br>
   ...
   ...
data = array("date_from" => $date_from, "date_to" => $date_to, "country" => $country);
}


我得到的数据看起来像这样

15.01.2020 --- 20.01.2020 ---国家0
01.02.2020 --- 05.02.2020 ---国家1
10.02.2020 --- 20.02.2020 ---国家2


这些日期指的是工人在国外开始和完成工作的时间。我需要获取日期以了解工人何时在本国工作。第一个日期之前,最后一个日期之后以及中间的日期表示在本国工作。我的最终数据应保存在数组中,如下所示:


2020年1月1日--- 2020年1月14日---主页

15.01.2020 --- 20.01.2020 ---国家0

2020年1月21日--- 31.01.2020 ---主页

01.02.2020 --- 05.02.2020 ---国家1

6.02.2020 --- 09.02.2020 ---主页

10.02.2020 --- 20.02.2020 ---国家2

2020年2月21日--- 31.12.2020 ---主页



2 个答案:

答案 0 :(得分:0)

我认为您的示例中的2019年是拼写错误,因为该数组的其余部分已正确排序。

在这里,我首先要确保第一项的日期是所述月份的第一天。如果不是,则添加月份的“开始”。

然后它进入循环并检查项目之间是否存在间隙,如果存在间隙则添加一个家庭项目。

$arr = array ( 0 => array ( 'datum_od' => '01.01.2020', 'datum_do' => '10.01.2020', ), 1 => array ( 'datum_od' => '15.01.2020', 'datum_do' => '20.01.2020', ), 2 => array ( 'datum_od' => '01.02.2020', 'datum_do' => '05.02.2020', ), 3 => array ( 'datum_od' => '25.11.2020', 'datum_do' => '25.12.2020', ));
$end_date = 0;

if(date('d', strtotime($arr[0]['datum_od'])) != '01'){
    $end_date = date('d.m.Y', strtotime($arr[0]['datum_od'] . ' -1 day')); 
    $new[] = array('datum_od' => date('01.m.Y', strtotime($arr[0]['datum_od'])), 'datum_do' => $end_date, 'home');
}

foreach($arr as $key => $item){
    if(date("d.m.Y", strtotime($end_date . " +1 day")) != date('d.m.Y', strtotime($item['datum_od']))){
        $end_date = date('d.m.Y', strtotime($item['datum_od'] . ' -1 day')); 
        $new[] = array('datum_od' => date('d.m.Y', strtotime($arr[$key-1]['datum_do'] . " +1 day")), 'datum_do' => $end_date, 'home');
        $new[] = $item;
    }else{
        $new[] = $item;
    }
}

var_dump($new);

https://3v4l.org/lCOGv

答案 1 :(得分:-1)

可以通过PHP实现

// First day of the month.
echo date('Y-m-01', strtotime($query_date));

// Last day of the month.
echo date('Y-m-t', strtotime($query_date));

例如:

while($row = $stmt->fetch()) {
$first_day = date('Y-m-01', strtotime($date_from));
$before_date_from= date('Y-m-d', strtotime($date_from." - 1 day"));
$last_day = date('Y-m-t', strtotime($date_from));
$after_date_to = date('Y-m-d', strtotime($date_to." + 1 day"));
$data[] = array("date_from" => $first_day, "date_to" => $before_date_from, "country" => "Home");
$data[] = array("date_from" => $date_from, "date_to" => $date_to, "country" => $country);
$data[] = array("date_from" => $after_date_to, "date_to" => $last_day, "country" => "Home");
}

print_r($data); // check your result here..