DateInterval с одним месяцем в массиве php

Как я могу получить месячный интервал в php используя DateInterval,

Если бы я выбрал 05 августа 2015 в качестве даты начала и 17 октября 2015 в качестве конечной даты вывод моего массива должен быть разделен на 3 массива:

  • 1-й массив для 05 августа 2015 г. — 31 августа 2015 г.
  • 2-й массив для 01 сентября 2015 — 30 сентября 2015
  • 3-й массив для 01 октября 2015 — 17 октября 2015

Мы можем добиться этого по php DateInterval функционировать?

0

Решение

Вы можете попробовать приведенный ниже код. Я не уверен, но вы можете получить то, что вы ищете

$interval = DateInterval::createFromDateString('1 month');
$period   = new DatePeriod($d1, $interval, $d2);

foreach ($period as $dt) {

if($dt->format("Y-m") == date("Y-m", strtotime($date1))){
$date_array[$dt->format("Y-m")] = array(
'start_date' => $startDate,
'end_date' => $dt->format("Y-m-t"),
);
}else if($dt->format("Y-m") == date("Y-m", strtotime($date2))){
$date_array[$dt->format("Y-m")] = array(
'start_date' => $dt->format("Y-m-").'01',
'end_date' => $endDate,
);
}else{
$date_array[$dt->format("Y-m")] = array(
'start_date' => $dt->format("Y-m-").'01',
'end_date' => $dt->format("Y-m-t"),
);
}
}

foreach( $date_array as $d_key=>$da ){
/* your stuff */
}
1

Другие решения

Это довольно просто, если вы познакомитесь с некоторыми из полезных встроенных в PHP классов Date / Time.

Ты можешь использовать DateTime, DateInterval а также DatePeriod добиться ваших результатов. Например:

<?php

// create start/end dates and interval
$start    = new DateTime('05 Aug 2015');
$end      = new DateTime('17 Oct 2015');
$interval = new DateInterval('P1D');

// DatePeriod excludes the last day
// so bump the end date by one
$end->modify('+1 day');

// create a DatePeriod for each day in range
$period = new DatePeriod($start, $interval, $end);

$months = [];

foreach ($period as $date) {
$months[$date->format('F')][] = $date->format('m/d/Y');
}

print_r($months);

Урожайность:

Array
(
[August] => Array
(
[0] => 08/05/2015
[1] => 08/06/2015
[2] => 08/07/2015
[3] => 08/08/2015
[4] => 08/09/2015
[5] => 08/10/2015
[6] => 08/11/2015
[7] => 08/12/2015
[8] => 08/13/2015
[9] => 08/14/2015
[10] => 08/15/2015
[11] => 08/16/2015
[12] => 08/17/2015
[13] => 08/18/2015
[14] => 08/19/2015
[15] => 08/20/2015
[16] => 08/21/2015
[17] => 08/22/2015
[18] => 08/23/2015
[19] => 08/24/2015
[20] => 08/25/2015
[21] => 08/26/2015
[22] => 08/27/2015
[23] => 08/28/2015
[24] => 08/29/2015
[25] => 08/30/2015
[26] => 08/31/2015
)

[September] => Array
(
[0] => 09/01/2015
[1] => 09/02/2015
[2] => 09/03/2015
[3] => 09/04/2015
[4] => 09/05/2015
[5] => 09/06/2015
[6] => 09/07/2015
[7] => 09/08/2015
[8] => 09/09/2015
[9] => 09/10/2015
[10] => 09/11/2015
[11] => 09/12/2015
[12] => 09/13/2015
[13] => 09/14/2015
[14] => 09/15/2015
[15] => 09/16/2015
[16] => 09/17/2015
[17] => 09/18/2015
[18] => 09/19/2015
[19] => 09/20/2015
[20] => 09/21/2015
[21] => 09/22/2015
[22] => 09/23/2015
[23] => 09/24/2015
[24] => 09/25/2015
[25] => 09/26/2015
[26] => 09/27/2015
[27] => 09/28/2015
[28] => 09/29/2015
[29] => 09/30/2015
)

[October] => Array
(
[0] => 10/01/2015
[1] => 10/02/2015
[2] => 10/03/2015
[3] => 10/04/2015
[4] => 10/05/2015
[5] => 10/06/2015
[6] => 10/07/2015
[7] => 10/08/2015
[8] => 10/09/2015
[9] => 10/10/2015
[10] => 10/11/2015
[11] => 10/12/2015
[12] => 10/13/2015
[13] => 10/14/2015
[14] => 10/15/2015
[15] => 10/16/2015
[16] => 10/17/2015
)

)

Просто чтобы заметить: вы указали, что хотите разбить результат на три отдельных массива. Я предполагаю, что результаты будут динамическими — в течение которых количество месяцев может варьироваться — поэтому я думаю, что вам лучше создавать многомерный массив результатов.

В приведенном выше примере я использовал названия месяцев в качестве ключей. $date->format('F') возвращает полное текстовое представление месяца, например, январь или март.

Если вы хотите получить список месяцев, содержащихся в $months массив вы можете просто сделать:

print_r(array_keys($months));

Который возвращает ключи и должен предоставить вам достаточно информации для доступа к данным для ваших нужд:

Array
(
[0] => August
[1] => September
[2] => October
)

Надеюсь это поможет 🙂

1

По вопросам рекламы [email protected]