Як я можу отримати останній день місяця в PHP?
Подано:
$a_date = "2009-11-23"
Я хочу 2009-11-30; і дано
$a_date = "2009-12-23"
Я хочу 2009-12-31.
Як я можу отримати останній день місяця в PHP?
Подано:
$a_date = "2009-11-23"
Я хочу 2009-11-30; і дано
$a_date = "2009-12-23"
Я хочу 2009-12-31.
Відповіді:
t
повертає кількість днів у місяці заданої дати (див . Документи дляdate
):
$a_date = "2009-11-23";
echo date("Y-m-t", strtotime($a_date));
DateTime
тобою можна зробити щось подібне:(new DateTime('2009-11-23'))->modify('last day of')
Код, що використовує 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' );
strtotime
код дає мені такий результат: 2040-11-30
Я знаю, що це трохи пізно, але я думаю, що існує більш елегантний спосіб зробити це PHP 5.3+
за допомогою класу DateTime :
$date = new DateTime('now');
$date->modify('last day of this month');
echo $date->format('Y-m-d');
$date = DateTime::createFromFormat('m/d/Y', '1/10/2014');
Існує також вбудована функція 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
Це має працювати:
$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/>';
Що не так - Найелегантніше для мене - використання DateTime
Цікаво, що я не бачу DateTime::createFromFormat
, однолінійний
$lastDay = \DateTime::createFromFormat("Y-m-d", "2009-11-23")->format("Y-m-t");
Ви можете створити дату для першого наступного місяця, а потім використовувати strtotime("-1 day", $firstOfNextMonth)
mktime(0, 0, 0, $month+1, 0, $year);
strtotime()
та mktime()
перешкоджає б. відомих помилок, таких як визначення дати на межі місяців та показники високосного року. Оскільки DateTime
це доступно, ви повинні використовувати цей клас, щоб уникнути будь-яких проблем у майбутньому. Як сказав багато разів до мене, обидві ці функції strtotime()
і mktime()
не зможе після 2038 Ось чому я downvoted ...
Спробуйте це, якщо ви використовуєте 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');
і так далі..
Ваше рішення тут ..
$lastday = date('t',strtotime('today'));
31
для September
чого, як відомо, це не правильно.
Останній день місяця можна знайти кількома способами. Але просто це можна зробити за допомогою функції PHP strtotime () та date (). Я думаю, що ваш остаточний код буде виглядати приблизно так:
$a_date = "2009-11-23";
echo date('Y-m-t',strtotime($a_date));
Але якщо ви використовуєте 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');
Також ви можете вирішити це за допомогою власної функції, як показано нижче:
/**
* 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);
Якщо ви використовуєте розширення API Carbon для PHP DateTime, останній день місяця ви можете отримати за допомогою:
$date = Carbon::now();
$date->addMonth();
$date->day = 0;
echo $date->toDateString(); // use toDateTimeString() to get date and time
$date->day = 0;
Якщо у вас є місяць з розумом, отримайте останню дату місяця,
public function getLastDateOfMonth($month)
{
$date = date('Y').'-'.$month.'-01'; //make date of month
return date('t', strtotime($date));
}
$this->getLastDateOfMonth(01); //31
Існують способи отримати останній день місяця.
//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]);
Я спізнююсь, але є кілька простих способів зробити це, як згадувалося:
$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 () - це мій шлях до повного контролю над усіма аспектами часу ... IE
echo "<br> ".date("Y-n-j",mktime (date("H"),date("i"),date("s"),(11+1),0,2009));
Якщо встановити день у 0 та перемістити місяць на 1, ви отримаєте останній день попереднього місяця. 0 і від’ємні числа мають однаковий вплив у різних аргументах. PHP: mktime - Посібник
Як мало хто сказав, що strtotime - це не найсміливіший шлях, і мало, якщо жоден не є дуже універсальним.
Я використовую strtotime з cal_days_in_month таким чином:
$date_at_last_of_month=date('Y-m-d', strtotime('2020-4-1
+'.(cal_days_in_month(CAL_GREGORIAN,4,2020)-1).' day'));
Я завернув його в свій клас помічників часу на побачення тут
https://github.com/normandqq/Date-Time-Helper
використовуючи
$dateLastDay = Model_DTHpr::getLastDayOfTheMonth();
І це робиться
Інший спосіб використання 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
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); }
}
Це набагато більш елегантний спосіб отримати кінець місяця:
$thedate = Date('m/d/Y');
$lastDayOfMOnth = date('d', mktime(0,0,0, date('m', strtotime($thedate))+1, 0, date('Y', strtotime($thedate))));
Ви можете використовувати 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";
Код пояснюється самостійно. Тож сподіваємось, що це допомагає.