如何找到该日期的最后一天?

时间:2009-11-06 10:27:50

标签: php date

如何在PHP中获取当月的最后一天?

假设:

$a_date = "2009-11-23"

我想要2009-11-30;并给出

$a_date = "2009-12-23"

我想要2009-12-31。

30 个答案:

答案 0 :(得分:723)

t返回指定日期的月份天数(请参阅the docs for date):

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

答案 1 :(得分:100)

使用strtotime()的代码将在2038年后失败。(在此主题的第一个答案中给出) 例如,尝试使用以下内容:

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

它将给出答案:1970-01-31

因此,应该使用DateTime函数而不是strtotime。 以下代码将在没有2038年问题的情况下运行:

$d = new DateTime( '2040-11-23' ); 
echo $d->format( 'Y-m-t' );

答案 2 :(得分:84)

我知道这有点晚了但我认为使用DateTime类通过PHP 5.3+进行此更优雅的方式:

$date = new DateTime('now');
$date->modify('last day of this month');
echo $date->format('Y-m-d');

答案 3 :(得分:64)

还有内置的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

答案 4 :(得分:24)

这应该有效:

$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/>';

答案 5 :(得分:17)

您可以为下个月的第一天创建日期,然后使用strtotime("-1 day", $firstOfNextMonth)

答案 6 :(得分:11)

试试这个,如果您使用的是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 :(得分:11)

出了什么问题 - 对我来说最优雅的是使用DateTime

我想知道我没有看到DateTime::createFromFormat,单行

$lastDay = \DateTime::createFromFormat("Y-m-d", "2009-11-23")->format("Y-m-t");

答案 8 :(得分:9)

您的解决方案就在这里..

$lastday = date('t',strtotime('today'));

答案 9 :(得分:7)

如果您对PHP DateTime使用Carbon API扩展,则可以使用以下命令获取该月的最后一天:

$date = Carbon::now();
$date->addMonth();
$date->day = 0;
echo $date->toDateString(); // use toDateTimeString() to get date and time 

答案 10 :(得分:5)

您可以通过多种方式找到本月的最后一天。但只是你可以使用PHP strtotime()date()函数执行此操作。我想你的最终代码看起来像这样:

$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

但如果你使用PHP&gt; = 5.2我强烈建议你使用新的DateTime对象。例如,如下所示:

/**
 * 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);

Live Demo

此外,您可以使用自己的功能解决此问题,如下所示:

{{1}}

答案 11 :(得分:4)

您也可以将它与日期时间一起使用

$date = new \DateTime();
$nbrDay = $date->format('t');
$lastDay = $date->format('Y-m-t');

答案 12 :(得分:2)

$date1 = $year.'-'.$month; 
$d = date_create_from_format('Y-m',$date1); 
$last_day = date_format($d, 't');

答案 13 :(得分:2)

使用Zend_Date非常简单:

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

答案 14 :(得分:2)

现在,如果您有月份和年份,DateTime可以很方便地完成此操作

$date = new DateTime('last day of '.$year.'-'.$month);

来自另一个DateTime对象,该对象将是

$date = new DateTime('last day of '.$otherdate->format('Y-m'));

答案 15 :(得分: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

答案 16 :(得分: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]); 

答案 17 :(得分:1)

我将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'));

答案 18 :(得分: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 - Manual

正如少数人所说,strtotime不是最坚实的方式,如果没有那么容易通用,那么很少。

答案 19 :(得分:0)

2 行代码就完成了:

$oDate = new DateTime("2019-11-23");

// now your date object has been updated with last day of month    
$oDate->setDate($oDate->format("Y"),$oDate->format("m"),$oDate->format("t"));

// or to just echo you can skip the above line using this
echo $oDate->format("Y-m-t");

答案 20 :(得分:0)

如果你想回到几个月前,你也可以这样做。

 $list = [
        0, 1, 2, 3
    ];

    $date = new \Datetime();
    $dates = [];
    foreach($list as $item)
    {

        $set = clone $date;
        $set->modify("-$item month ");
       $dates[] = $set->modify("last day of this month");
       
    }
    return $dates;

答案 21 :(得分:0)

我需要下个月的最后一天,也许有人会需要它:

echo date("Y-m-t", strtotime("next month")); //is 2020-08-13, return 2020-09-30

答案 22 :(得分:0)

    $startDate = '2011-12-01';
    $endDate = date('Y-m');
    while (true) {
        try {
            $startDateTime = new DateTime($startDate);
            $startDateTime->add(new DateInterval('P1M'));
            $startDate = $startDateTime->format('Y-m-d');
            $endTime = $startDateTime->format('Y-m-t');
            echo $startDate . ' => ' . $endTime . PHP_EOL;
            if ($startDateTime->format('Y-m') == $endDate) {
                break;
            }
        } catch (Exception $exception) {
            var_dump($exception->getMessage());
            break;
        }
    }

在测试了许多解决方案之后,这对我来说最合适。

答案 23 :(得分:0)

  

如果您有一个月的时间,那么请获取该月的最后一个日期,

public function getLastDateOfMonth($month)
    {
        $date = date('Y').'-'.$month.'-01';  //make date of month 
        return date('t', strtotime($date)); 
    }

$this->getLastDateOfMonth(01); //31

答案 24 :(得分:0)

PHP日期时间的

Carbon API扩展

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

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

将退回

30

答案 25 :(得分: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

答案 26 :(得分:0)

我把它包装在我的日期时间助手课程中 https://github.com/normandqq/Date-Time-Helper 运用     $dateLastDay = Model_DTHpr::getLastDayOfTheMonth();

完成了

答案 27 :(得分:-1)

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

答案 28 :(得分:-2)

这是一个更优雅的方式来结束月份:

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

答案 29 :(得分:-3)

您可以在日期函数中使用“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";

代码是自我解释的。希望它有所帮助。