<?php
/**
* 返回上个月所有周开始结束时间结束时间(第一周不足7天取从上上个月底的日期) 从周一到周日
* @return array()
*/
function lastMonthWeek($params = array())
{
$result = [];
$monthDays = 30;
// 上个月为2月时做特殊处理
if (date('m') == 3)
{
$monthDays = 28;
}
$date = date('Y-m-'.$monthDays.' H:i:s');
if (isset($params['date']) && (!empty($params['date'])))
{
$date = date('Y-m-28 H:i:s', strtotime($params['date']));
}
$time = strtotime('last month', strtotime($date));
$lastMonth = date('n', $time);
// 最后一天日期
$endDate = date('Y-m-d H:i:s', mktime(23, 59, 59, date("m",$time), date('t',$time), date("Y",$time)));
// 上个月最后一天是周几
$time = strtotime($endDate);
// 最后一天是周几 0(表示星期天)到 6(表示星期六)
$endDayWeek = date('w', $time);
$startTime = '';
$endTime = '';
if ($endDayWeek == 0)
{
// 最后一周结束日期
$endTime = $endDate;
}
else
{
// 最后一周结束日期
$endTime = date('Y-m-d H:i:s', strtotime($endDate) + (7 - $endDayWeek) * 86400);
}
// 最后一周开始日期
$startTime = date('Y-m-d H:i:s', strtotime($endTime) - 7*86400+1);
array_unshift($result, ['startTime' => $startTime, 'endTime' => $endTime]);
while (true)
{
$startMonth = date('n', strtotime($startTime));
if (($startMonth < $lastMonth) || ($startMonth == 12 && $lastMonth == 1))
{
break;
}
$endTime = date('Y-m-d 23:59:59', strtotime($startTime) - 86400 +1);
$startTime = date('Y-m-d H:i:s', strtotime($endTime) - 7*86400+1);
// echo $startTime, ' ', $endTime, "<br><br>";
array_unshift($result, ['startTime' => $startTime, 'endTime' => $endTime]);
}
return $result;
}
// 当前日期
$date = '2020-01';
$dateData = lastMonthWeek(['date' => $date]);
print_r($dateData);
返回值 (当前日期 2019-10-21)
Array
(
[0] => Array
(
[startTime] => 2019-08-26 00:00:00
[endTime] => 2019-09-01 23:59:59
)
[1] => Array
(
[startTime] => 2019-09-02 00:00:00
[endTime] => 2019-09-08 23:59:59
)
[2] => Array
(
[startTime] => 2019-09-09 00:00:00
[endTime] => 2019-09-15 23:59:59
)
[3] => Array
(
[startTime] => 2019-09-16 00:00:00
[endTime] => 2019-09-22 23:59:59
)
[4] => Array
(
[startTime] => 2019-09-23 00:00:00
[endTime] => 2019-09-29 23:59:59
)
)