Этот код будет делать то, что вы хотите.Он преобразует каждое значение даты в объект DateTime
, находит начало и конец недели для этой даты, а затем помещает значение в новый массив, индексированный значениями начала и конца недели:
$date = array('01-01-2019','02-01-2019','05-01-2019','22-01-2019','02-02-2019','03-02-2019','24-02-2019');
$dates = array();
foreach ($date as $d) {
$od = date_create_from_format('d-m-Y', $d);
// get start and end of this week
$sow = $od->sub(new DateInterval('P' . ($od->format('N') - 1). 'D'))->format('d-m-Y');
$eow = $od->add(new DateInterval('P6D'))->format('d-m-Y');
$dates["$sow/$eow"][] = $d;
}
print_r($dates);
Вывод:
Array (
[31-12-2018/06-01-2019] => Array (
[0] => 01-01-2019
[1] => 02-01-2019
[2] => 05-01-2019
)
[21-01-2019/27-01-2019] => Array (
[0] => 22-01-2019
)
[28-01-2019/03-02-2019] => Array (
[0] => 02-02-2019
[1] => 03-02-2019
)
[18-02-2019/24-02-2019] => Array (
[0] => 24-02-2019
)
)
Демонстрация на 3v4l.org