Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: разбить период дат , на подпериоды по месяцам

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
lashuk
Отправлено: 27 Ноября, 2014 - 11:37:50
Post Id


Новичок


Покинул форум
Сообщений всего: 3
Дата рег-ции: Нояб. 2014  


Помог: 0 раз(а)




Доброго времени суток.

Есть начальная дата 2014-01-16 и допустим есть конечная дата 2014-03-24

Мне надо из этих двух дат т.е. от 2014-01-16 и до 2014-03-24 разбить по месяцам. примерно, то что надо получить

(2014-01-16 | 2014-01-31)
(2014-02-01 | 2014-02-28)
(2014-03-01 | 2011-03-24) .

Заранее благодарен.
 
 Top
Мелкий Супермодератор
Отправлено: 27 Ноября, 2014 - 12:29:31
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




В принципе, этим занимается штатный класс DatePeriod http://php.net/manual/en/class.dateperiod.php

Но порой он работает не так, как ожидается, я предпочитаю такие задачи итерировать как-то так:
PHP:
скопировать код в буфер обмена
  1. $rFrom = new \datetime('2013-01-29');
  2. $rTill = new \datetime('2014-03-24');
  3. for ($rMonth = clone $rFrom; $rMonth <= $rTill; $rMonth->modify('first day of next month')) {
  4.         echo $rMonth->format('Y-m-d'),' - ', $rMonth->format('Y-m-t'),PHP_EOL;
  5.         }


-----
PostgreSQL DBA
 
 Top
lashuk
Отправлено: 27 Ноября, 2014 - 18:50:10
Post Id


Новичок


Покинул форум
Сообщений всего: 3
Дата рег-ции: Нояб. 2014  


Помог: 0 раз(а)




Проблема в том, что этот код должен первый подпериод начать с даты 2013-01-29-2013-01-31,в середине должны быть полные месяцы с 1 числа по 31 и конечный подпериод должен начаться с 2014-03-01 а закончиться указанной датой в полном периоде т.е 2014-03-24.
 
 Top
Sail
Отправлено: 27 Ноября, 2014 - 19:24:39
Post Id



Участник


Покинул форум
Сообщений всего: 1131
Дата рег-ции: Февр. 2014  


Помог: 57 раз(а)




lashuk пишет:
Проблема в том, что этот код должен первый подпериод начать с даты 2013-01-29-2013-01-31,в середине должны быть полные месяцы с 1 числа по 31 и конечный подпериод должен начаться с 2014-03-01 а закончиться указанной датой в полном периоде т.е 2014-03-24.

Разве-ж это проблема?
Например, можно так модифицировать вышеприведённый код:
PHP:
скопировать код в буфер обмена
  1.     $rFrom = new \datetime('2013-01-29');
  2.     $rTill = new \datetime('2014-03-24');
  3.     for ($rMonth = clone $rFrom; $rMonth <= $rTill; $rMonth->modify('first day of next month')) {
  4.             echo $rMonth->format('Y-m-d'),' - ', min($rTill->format('Y-m-d'), $rMonth->format('Y-m-t')),PHP_EOL;
  5.             }
 
 Top
lashuk
Отправлено: 27 Ноября, 2014 - 19:41:49
Post Id


Новичок


Покинул форум
Сообщений всего: 3
Дата рег-ции: Нояб. 2014  


Помог: 0 раз(а)




Всем спасибо, очень помогло
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Хранение данных, их вывод и обработка »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB