您好,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 ---主页
答案 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);
答案 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..