日付から月の最後の日を見つける方法は?


382

PHPで月の最終日を取得するにはどうすればよいですか?

与えられた:

$a_date = "2009-11-23"

2009-11-30が欲しい。そして与えられた

$a_date = "2009-12-23"

2009-12-31が欲しい。

回答:


805

t指定された日付の月の日数を返します(のドキュメントをdate参照):

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

99
これは2038年後に失敗します。そのため、strtotimeの代わりに、DateTime関数を使用する必要があります。次のコードは2038年の問題がなくても機能します。$ d = new DateTime( '2009-11-23'); echo $ d-> format( 'Ymt');
Mugunth 2012年

74
@Mugunth 24年後の日付で作業している場合、2038年よりも早く問題が発生する可能性がありますが、サーバーは既に64ビットアーキテクチャに移行しており、問題を修正するのに約292億年かかります。
なし

1
手続き型-> $ date1 = $ year .'- '。$ month; $ d = date_create_from_format( 'Y-m'、$ date1); $ last_day = date_format($ d、 't');
kayla 2013

11
DateTime:あなたはこのような何か行うことができます(new DateTime('2009-11-23'))->modify('last day of')
ビクター

Carbon PHPを使用している場合は、daysInMonthゲッターを使用できます
astroanu

119

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

17
私は71歳で、それまでに引退するので、私には問題ありません。j / kしかし、真剣に人々-この警告に注意してください!
Volomike

17
これは、32ビットバージョンのPHPを実行していることを前提としています。
なし

php docu php.net/manual/de/function.strtotime.phpに strtotimeに関するこの驚くべき事実が記載されていないのはなぜですか?
アダム

1
@アダムそれはあなたがチェックしたときだったかどうか、今ではわかりません。php.net/manual/de/...
MAVE

1
2018年の時点で、strtotimeコードにより次の結果が得られます:2040-11-30
Jee

104

私はこれが少し遅れていることを知っていますがPHP 5.3+DateTimeクラスを使用してこれを行うよりエレガントな方法があると思います:

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

20
1行で:$ date = new DateTime( 'last day of this month');
ハロルド

6
$ date-> modify( 'last day of this month')-> setTime(23,59,59);を追加することもできます。時間の問題がある場合に、このdateTimeを比較に使用する場合。(これにより、月の最後の秒が表示されます)
omgitsdrobinoha 2016年

5
これは機能します:$date = new DateTime('last day of 2020-2');

4
@ジョンあなたは間違っています。最終日は、システム日付ではなく、$ dateオブジェクトを使用して計算されます。これで最初の行を変更して試してみよう:$date = DateTime::createFromFormat('m/d/Y', '1/10/2014');
Hannoun Yassir

5
あなたが考えることをしたか、少なくとも試みでなら、私が何をあなたに求めて何をすることを見ることが、今月は、 DateTimeオブジェクトの月の値ではなく、システムの日付を意味します。:あなたは/実行PHPコードに、このかもしれないのヘルプを入力することができない場合sandbox.onlinephpfunctions.com/code/...
Hannoun Yassir

76

組み込みの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

2
この答えは、strtoTimeを使用するよりもはるかに簡単で適切です。欠点はありません。トップに行きます。
Tomas Zubiri 2016年

これは受け入れられるべき答えでした。
sieppl

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

18

何が問題なのか-私にとって最もエレガントなのは DateTime

見えないかなDateTime::createFromFormat、ワンライナー

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

2
同意する。このソリューション(DateTimeクラス)は、古い日時関数を使用するよりもはるかに優れています。
schellingerht 2017年

17

あなたは翌月の最初の日付を作成してから、 strtotime("-1 day", $firstOfNextMonth)


同じアプローチを使用する別の方法は、mktimeに翌月の0日を与えることですmktime(0, 0, 0, $month+1, 0, $year);
George

私としては、の使用方法strtotime()とはmktime()BECお勧めしません。月の端の日付決定やうるう年の計算などの既知のバグの数。以来DateTime利用可能である、あなたは、将来的にすべての問題を避けるために、このクラスを使用する必要があります。同様に、これらの両方の機能を、私の前に何回も言ったstrtotime()し、mktime()2038年後に失敗することを、私はdownvoted理由の...
ポール・T. Rawkeen

@ PaulT.Rawkeenこの回答は4年以上前のものです。インターネット上の他のことと同様に、関連性と有用性を評価するときは年齢が要因になるはずです。さらに、私見、技術に関連するものの半分になる時間は特に短いです。
nikc.org 2013

@ nikc.org私は同意します。特に、すべての技術的ソリューションの寿命と問題の解決方法に関してです。この特定のケースでは、回答の賛成票の数は比較的多く、おそらく誰か(ジュニアプログラマー)がこの回答を許容できる解決策と見なすでしょう。それは短くてエレガントです:)そして彼はおそらく期待される結果を得るでしょうが、時間が経つにつれて、このような種類の問題を解決するこの方法はトリッキーになり、可能であればそのような事実について警告する必要があります。よろしくお願いします。
Paul T. Rawkeen

16

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

等々..



10

月の最終日はいくつかの方法で見つけることができます。しかし、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);

あなたの機能をありがとう、それは私が期待したように動作します:)
Mankeomorakort

7

PHP DateTimeにCarbon API拡張機能を使用する場合、次のコマンドで月の最終日を取得できます。

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

実際、日を-1に設定すると、最後の1つが取得されます。したがって、最終日を取得するには、日を0に設定する必要があります。$date->day = 0;
Giovanne Afonso、

ありがとうございます@GiovanneAfonso正解です。私は日を0に設定し、答えをテストしました。
eaykin 2014年

1
Carbonを使用している場合は、Carbon :: Now()-> endOfMonth()を使用するという簡単な方法があります。ただし、endOfMonth()は修飾子なので、Carbon日付を保持している既存の変数がある場合は「clone」を使用します(または日付が変更されます)。
Charlie Dalsass

4

日時とともに使用することもできます

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

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

2

Zend_Dateを使用すると、非常に簡単です。

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

2

月がある場合は、その月の最後の日付を取得します。

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

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

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


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

私は遅れていますが、これを行う簡単な方法がいくつかあります。

$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が最も堅実な方法ではなく、どれも簡単に多目的に使用できるとは限らないと言っている人もいます。


1

次のように、cal_days_in_monthでstrtotimeを使用しています。

$date_at_last_of_month=date('Y-m-d', strtotime('2020-4-1
+'.(cal_days_in_month(CAL_GREGORIAN,4,2020)-1).' day'));


0

date( 't')ではなくmktimeを使用する別の方法:

$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

PHP DateTime用のCarbon API拡張

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

または

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

戻ります

30

-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


-2

これは、月末を取得するためのよりエレガントな方法です。

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

-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";

コードは自明です。それが役に立てば幸いです。

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.