จะหาวันสุดท้ายของเดือนได้อย่างไร?


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

74
@Mununth หากคุณทำงานกับเดท 24 ปีในอนาคตคุณอาจพบปัญหาเร็วกว่า 2038 อย่างไรก็ตามเซิร์ฟเวอร์กำลังเคลื่อนไปยังสถาปัตยกรรม 64 บิตซึ่งจะให้เราประมาณ 292 พันล้านปีเพื่อแก้ไขปัญหา
ไม่มี

1
ในขั้นตอน -> $ date1 = $ year .'- '. $ เดือน; $ d = date_create_from_format ('Y-m', $ date1); $ last_day = date_format ($ d, 't');
kayla

11
ด้วยDateTimeคุณสามารถทำอะไรเช่นนี้:(new DateTime('2009-11-23'))->modify('last day of')
วิกเตอร์

หากคุณใช้ Carbon PHP คุณสามารถใช้วันได้ในเดือนกันยายน
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
สิ่งนี้ถือว่าคุณใช้งาน PHP เวอร์ชัน 32 บิต
ไม่มี

นี่คือเหตุผลที่ความเป็นจริงที่น่ากลัวเกี่ยวกับ strtotime ไม่ได้กล่าวถึงใน PHP docu php.net/manual/de/function.strtotime.php ?
อดัม

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
ในหนึ่งบรรทัด: $ date = new DateTime ('วันสุดท้ายของเดือนนี้');
แฮโรลด์

6
คุณอาจต้องการเพิ่ม $ date-> modified ('วันสุดท้ายของเดือนนี้') -> setTime (23,59,59); หากคุณต้องการใช้ dateTime นี้เพื่อเปรียบเทียบเวลาที่สำคัญ (สิ่งนี้จะให้วินาทีสุดท้ายของเดือน)
omgitsdrobinoha

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

นี่ควรเป็นคำตอบที่ยอมรับได้
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

17

คุณสามารถสร้างวันที่สำหรับเดือนแรกของเดือนถัดไปจากนั้นใช้ strtotime("-1 day", $firstOfNextMonth)


วิธีการทางเลือกที่ใช้วิธีการเดียวกันคือการให้ mktime ในวันที่ 0 ของเดือนถัดไปmktime(0, 0, 0, $month+1, 0, $year);
George

สำหรับฉันแล้วการใช้งานstrtotime()และmktime()เป็นกำลังใจ ของข้อบกพร่องที่รู้จักกันเช่นการกำหนดวันที่บนขอบของเดือนและ calaculations ปีอธิกสุรทิน เนื่องจากDateTimeมีให้บริการคุณควรใช้คลาสนี้เพื่อหลีกเลี่ยงปัญหาใด ๆ ในอนาคต เช่นเดียวกับหลายครั้งก่อนหน้าฉันทั้งสองฟังก์ชั่นเหล่านี้strtotime()และmktime()จะล้มเหลวหลังจากปี 2038 นั่นเป็นเหตุผลที่ฉัน downvote ...
Paul T. Rawkeen

@ PaulT.Rawkeen คำตอบนี้มีอายุมากกว่า 4 ปี เช่นเดียวกับสิ่งใด ๆ บนอินเทอร์เน็ตอายุควรเป็นปัจจัยหนึ่งในการประเมินความเกี่ยวข้องและประโยชน์ ยิ่งไปกว่านั้น IMHO เวลาแบ่งครึ่งสำหรับทุกสิ่งที่เกี่ยวข้องกับเทคโนโลยีนั้นสั้นมาก
nikc.org

@ nikc.org ฉันเห็นด้วยโดยเฉพาะอย่างยิ่งเกี่ยวกับเวลาของชีวิตสำหรับการแก้ปัญหาด้านเทคนิคและวิธีการแก้ปัญหา ในกรณีนี้คำตอบมีจำนวน upvotes ค่อนข้างดีและน่าจะมีบางคน ( โปรแกรมเมอร์อาวุโส ) พิจารณาคำตอบนี้ว่าเป็นคำตอบที่ยอมรับได้ มันสั้นและสง่างาม :) และเขาอาจจะได้รับผลตามที่คาดหวัง แต่เมื่อเวลาผ่านไปวิธีแก้ปัญหาแบบนี้จะยุ่งยากและเราควรเตือนเกี่ยวกับข้อเท็จจริงดังกล่าวเมื่อเป็นไปได้ ขอแสดงความนับถือ
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');

และอื่น ๆ ..


11

ทางออกของคุณอยู่ที่นี่ ..

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

1
นี้จะช่วยให้31สำหรับSeptemberที่ที่คุณรู้ที่ไม่ถูกต้อง
Iliyass Hamza

10

คุณสามารถหาวันสุดท้ายของเดือนได้หลายวิธี แต่คุณสามารถทำได้โดยใช้ PHP strtotime ()และdate () function ฉันคิดว่าโค้ดสุดท้ายของคุณจะมีลักษณะดังนี้:

$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

หากคุณใช้ส่วนขยายCarbon API สำหรับ PHP DateTime คุณสามารถรับวันสุดท้ายของเดือนด้วย:

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

ที่จริงแล้วถ้าคุณตั้งค่าวันเป็น -1 มันจะได้ค่าสุดท้าย แต่อย่างใดอย่างหนึ่ง ดังนั้นคุณต้องตั้งค่าวันเป็น 0 เพื่อให้ได้วันสุดท้าย $date->day = 0;
Giovanne Afonso

ขอบคุณ @GiovanneAfonso ที่ถูกต้อง ฉันตั้งวันเป็น 0 และทดสอบคำตอบ
eaykin

1
หากคุณใช้ Carbon วิธีการหนึ่งซับคือการใช้: Carbon :: Now () -> endOfMonth () อย่างไรก็ตาม endOfMonth () เป็นตัวดัดแปลงดังนั้นให้ใช้ "clone" หากคุณมีตัวแปรที่มีอยู่ที่เก็บวันที่ของคาร์บอน (หรือวันที่จะถูกแก้ไข)
Charlie Dalsass

4

คุณสามารถใช้กับ datetime ได้

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



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

ฉันกำลังใช้ 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'));


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

ส่วนต่อขยายCarbon API สำหรับ PHP DateTime

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.