Как найти последний день месяца с даты?

257

Как я могу получить последний день месяца в PHP?

Дано:

$a_date = "2009-11-23"

Я хочу 2009-11-30; и учитывая

$a_date = "2009-12-23"

Я хочу 2009-12-31.

Теги:
date

23 ответа

566
Лучший ответ

t возвращает количество дней в месяце данной даты (см. документы для date):

$a_date = "2009-11-23";
echo date("Y-m-t", strtotime($a_date));
  • 5
    дата эха ("Ymt", strtotime ($ a_date)); работал нормально.
  • 83
    Это не удастся после 2038 года. Поэтому вместо strtotime следует использовать функцию DateTime. Следующий код будет работать без проблем 2038 года: $ d = new DateTime ('2009-11-23'); echo $ d-> format ('Ymt');
Показать ещё 5 комментариев
88

Код с использованием strtotime() завершится неудачно после 2038 года (как указано в первом ответе в этом потоке) Например, попробуйте использовать следующее:

$a_date = "2040-11-23";
echo date("Y-m-t", strtotime($a_date));

Он даст ответ как: 1970-01-31

Поэтому вместо strtotime следует использовать функцию DateTime. Следующий код будет работать без проблемы года 2038:

$d = new DateTime( '2040-11-23' ); 
echo $d->format( 'Y-m-t' );
  • 10
    Мне будет 71 год, и я уйду на пенсию, так что для меня это не проблема! j / k А если серьезно, ребята - учтите это предупреждение!
  • 15
    Это предполагает, что вы используете 32-битную версию PHP.
Показать ещё 3 комментария
66

Я знаю, что это немного поздно, но я думаю, что есть более элегантный способ сделать это с помощью PHP 5.3+ с помощью DateTime class:

$date = new DateTime('now');
$date->modify('last day of this month');
echo $date->format('Y-m-d');
  • 18
    В одной строке: $ date = new DateTime («последний день этого месяца»);
  • 3
    Возможно, вы захотите добавить $ date-> modify ('последний день этого месяца') -> setTime (23,59,59); если вы хотите использовать этот dateTime для сравнения, когда время имеет значение. (Это дает вам последнюю секунду месяца)
Показать ещё 5 комментариев
50

Существует также встроенная функция PHP cal_days_in_month()?

"Эта функция вернет количество дней в месяце года для указанного календаря." http://php.net/manual/en/function.cal-days-in-month.

echo cal_days_in_month(CAL_GREGORIAN, 11, 2009); 
// = 30
  • 0
    Этот ответ намного проще и уместнее, чем использование strtoTime. Я не вижу никаких минусов. К вершине вы идете.
22

Это должно работать:

$week_start = strtotime('last Sunday', time());
$week_end = strtotime('next Sunday', time());

$month_start = strtotime('first day of this month', time());
$month_end = strtotime('last day of this month', time());

$year_start = strtotime('first day of January', time());
$year_end = strtotime('last day of December', time());

echo date('D, M jS Y', $week_start).'<br/>';
echo date('D, M jS Y', $week_end).'<br/>';

echo date('D, M jS Y', $month_start).'<br/>';
echo date('D, M jS Y', $month_end).'<br/>';

echo date('D, M jS Y', $year_start).'<br/>';
echo date('D, M jS Y', $year_end).'<br/>';
16

Вы можете создать дату для первого из следующего месяца, а затем использовать strtotime("-1 day", $firstOfNextMonth)

  • 0
    альтернативный метод, использующий тот же подход, состоит в том, чтобы присвоить mktime 0-й день следующего месяца mktime(0, 0, 0, $month+1, 0, $year);
  • 0
    Что касается меня, то использование strtotime() и mktime() не рекомендуется. из известных ошибок, таких как определение даты на границе месяцев и високосных годов. Поскольку DateTime доступен, вы должны использовать этот класс, чтобы избежать каких-либо проблем в будущем. Как уже много раз говорилось до меня, обе эти функции strtotime() и mktime() потерпят неудачу после 2038 года. Вот почему я отказался ...
Показать ещё 2 комментария
9

Ваше решение здесь..

$lastday = date('t',strtotime('today'));
  • 1
    это дает 31 за September что, как вы знаете, это не правильно.
8

Попробуйте, если вы используете PHP 5.3 +,

$a_date = "2009-11-23";
$date = new DateTime($a_date);
$date->modify('last day of this month');
echo $date->format('Y-m-d');

Для поиска последней даты последнего месяца измените следующим образом:

 $date->modify('last day of 1 month');
 echo $date->format('Y-m-d');

и т.д.

7

Если вы используете расширение API Carbon для PHP DateTime, вы можете получить последний день месяца:

$date = Carbon::now();
$date->addMonth();
$date->day = 0;
echo $date->toDateString(); // use toDateTimeString() to get date and time 
  • 0
    На самом деле, если вы установите день на -1, он получит последний, но один. Таким образом, вы должны установить день на 0, чтобы получить последний день. $date->day = 0;
  • 0
    спасибо @ GiovanneAfonso, это правильно. Я установил день на 0 и проверил ответ.
Показать ещё 1 комментарий
5

Что случилось с вами, ребята? Самый элегантный - DateTime

Интересно, я не вижу DateTime::createFromFormat, один лайнер

$lastDay = \DateTime::createFromFormat("Y-m-d", "2009-11-23")->format("Y-m-t");
  • 1
    Согласен. Это решение (класс DateTime) намного лучше, чем использование старых функций datetime.
4

Вы можете найти последний день месяца несколькими способами. Но просто вы можете сделать это, используя PHP strtotime() и date ( ). Я предполагаю, что ваш последний код будет выглядеть примерно так:

$a_date = "2009-11-23";
echo date('Y-m-t',strtotime($a_date));

Live Demo

Но если вы используете PHP >= 5.2, я настоятельно рекомендую вам использовать новый объект DateTime. Например, как показано ниже:

$a_date = "2009-11-23";
$date = new DateTime($a_date);
$date->modify('last day of this month');
echo $date->format('Y-m-d');

Live Demo

Кроме того, вы можете решить эту проблему, используя свою собственную функцию, как показано ниже:

/**
 * Last date of a month of a year
 *
 * @param[in] $date - Integer. Default = Current Month
 *
 * @return Last date of the month and year in yyyy-mm-dd format
 */
function last_day_of_the_month($date = '')
{
    $month  = date('m', strtotime($date));
    $year   = date('Y', strtotime($date));
    $result = strtotime("{$year}-{$month}-01");
    $result = strtotime('-1 second', strtotime('+1 month', $result));

    return date('Y-m-d', $result);
}

$a_date = "2009-11-23";
echo last_day_of_the_month($a_date);
3

Вы также можете использовать его с datetime

$date = new \DateTime();
$nbrDay = $date->format('t');
$lastDay = $date->format('Y-m-t');
2
$date1 = $year.'-'.$month; 
$d = date_create_from_format('Y-m',$date1); 
$last_day = date_format($d, 't');
1

Я опаздываю, но есть несколько простых способов сделать это, как упомянуто:

$days = date("t");
$days = cal_days_in_month(CAL_GREGORIAN, date('m'), date('Y'));
$days = date("j",mktime (date("H"),date("i"),date("s"),(date("n")+1),0,date("Y")));

Использование mktime() - это мой полный контроль над всеми аспектами времени... То есть.

echo "<br> ".date("Y-n-j",mktime (date("H"),date("i"),date("s"),(11+1),0,2009));

Установка дня на 0 и перемещение вашего месяца до 1 даст вам последний день предыдущего месяца. 0, а отрицательные числа имеют аналогичный аффект в разных аргументах. PHP: mktime - Руководство

Как уже было сказано, strtotime не самый надежный способ пойти, и мало, если никто не будет столь же легко универсальным.

1

Carbon Расширение API для PHP DateTime

Carbon::parse("2009-11-23")->lastOfMonth()->day;

или

Carbon::createFromDate(2009, 11, 23)->lastOfMonth()->day;

выберет

30
1

Использование Zend_Date довольно легко:

$date->setDay($date->get(Zend_Date::MONTH_DAYS));
1

Есть способы получить последний день месяца.

//to get last day of current month
echo date("t", strtotime('now'));

//to get last day from specific date
$date = "2014-07-24";
echo date("t", strtotime($date));

//to get last day from specific date by calendar
$date = "2014-07-24";
$dateArr=explode('-',$date);
echo cal_days_in_month(CAL_GREGORIAN, $dateArr[1], $dateArr[0]); 
1

Вот полная функция:

public function get_number_of_days_in_month($month, $year) {
    // Using first day of the month, it doesn't really matter
    $date = $year."-".$month."-1";
    return date("t", strtotime($date));
}

Это будет выводиться следующим образом:

echo get_number_of_days_in_month(2,2014);

Выход: 28

0

Другой способ: mktime, а не дата ('t'):

$dateStart= date("Y-m-d", mktime(0, 0, 0, 10, 1, 2016)); //2016-10-01
$dateEnd = date("Y-m-d", mktime(0, 0, 0, 11, 0, 2016)); //This will return the last day of october, 2016-10-31 :)

Таким образом, он вычисляет либо, если он равен 31,30 или 29

0

Я завернул его в мой класс времени для ввода данных здесь https://github.com/normandqq/Date-Time-Helper с помощью   $dateLastDay = Model_DTHpr::getLastDayOfTheMonth();

И это делается

0
function first_last_day($string, $first_last, $format) {
    $result = strtotime($string);
    $year = date('Y',$result);
    $month = date('m',$result);
    $result = strtotime("{$year}-{$month}-01");
    if ($first_last == 'last'){$result = strtotime('-1 second', strtotime('+1 month', $result)); }
    if ($format == 'unix'){return $result; }
    if ($format == 'standard'){return date('Y-m-d', $result); }
}

http://zkinformer.com/?p=134

  • 2
    first_last_day ? :-(
-2

Это гораздо более элегантный способ получить конец месяца:

  $thedate = Date('m/d/Y'); 
  $lastDayOfMOnth = date('d', mktime(0,0,0, date('m', strtotime($thedate))+1, 0, date('Y', strtotime($thedate)))); 
-4

Вы можете использовать "t" в функции даты, чтобы получить количество дней в конкретном месяце.

Код будет примерно таким:

function lastDateOfMonth($Month, $Year=-1) {
    if ($Year < 0) $Year = 0+date("Y");
    $aMonth         = mktime(0, 0, 0, $Month, 1, $Year);
    $NumOfDay       = 0+date("t", $aMonth);
    $LastDayOfMonth = mktime(0, 0, 0, $Month, $NumOfDay, $Year);
    return $LastDayOfMonth;
}

for($Month = 1; $Month <= 12; $Month++)
    echo date("Y-n-j", lastDateOfMonth($Month))."\n";

Код сам объясняется. Поэтому надеюсь, что это поможет.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню