@AlexRas

Как сформировать массив дат начала и конца месяцев в выбранном диапазоне?

Здравствуйте, подскажите как такое сделать.

Есть произвольные даты в формате:
Начало - 07.02.2019 22:10:56
Конец - 22.04.2019 19:22:35

На основе этих дат нужно сделать такой массив:
$dates = [
    ['07.02.2019 22:10:56', '28.02.2019 23:59:59'],
    ['01.03.2019 00:00:00', '31.03.2019 23:59:59'],
    ['01.04.2019 00:00:00', '22.04.2019 19:22:35'],
];
  • Вопрос задан
  • 125 просмотров
Решения вопроса 1
Matmode
@Matmode
PHP/Symfony Developer
AlexRas Полагаю, в примере есть неверные данные

Решение при корректных входных данных
<?php

function generateDatesRange($from, $to)
{
    $from = new \DateTime($from);
    $to = new \DateTime($to);

    $start = new \DateTime($from->format('01.m.Y 00:00:00'));

    $dates = [];
    while ($start <= $to) {
        $dates[] = $start->format('d.m.Y 00:00:00');
        $dates[] = $start->format('t.m.Y 23:59:59');
        $start->modify('+1 month');
    }

    $dates[0] = $from->format('d.m.Y H:i:s');
    $dates[count($dates) - 1] = $to->format('d.m.Y H:i:s');

    return array_chunk($dates, 2);
}

$from = '07.02.2019 22:10:56';
$to = '22.04.2019 19:22:35';

$result = generateDatesRange($from, $to);

print_r($result);


Результат
php index.php
Array
(
    [0] => Array
        (
            [0] => 07.02.2019 22:10:56
            [1] => 28.02.2019 23:59:59
        )

    [1] => Array
        (
            [0] => 01.03.2019 00:00:00
            [1] => 31.03.2019 23:59:59
        )

    [2] => Array
        (
            [0] => 01.04.2019 00:00:00
            [1] => 22.04.2019 19:22:35
        )

)
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы
Aitarget Москва
от 100 000 руб.
Click Санкт-Петербург
от 110 000 до 150 000 руб.
ASTRIO agency Ульяновск
от 30 000 до 100 000 руб.
20 мая 2019, в 15:24
1000 руб./в час
20 мая 2019, в 14:57
100 руб./за проект
20 мая 2019, в 14:54
7000 руб./за проект