Mithun Sreedharan
Mithun Sreedharan

Reputation: 51274

PHP 'end date' from a given 'start date' - last day/15th of the following month

I'd like to get an 'end date' from a given 'start date' in PHP. End date is based off the start and are calculated as follows:

If Start date is from the 1-15th of the month, End date is the 15th of the following month.

If Start date is from the 16-31 of the month, End date is the last day of the following month.

eg: $start_date = '2009-11-23';

Upvotes: 0

Views: 1428

Answers (2)

GZipp
GZipp

Reputation: 5416

Here's another way to do it:

$dt = new DateTime($start_date);
if ($dt->format('d') > 15) {
    $day = 'last day';
} else {
    $day = (15 - $dt->format('d')) . ' days';
}
echo $dt->modify('next month ' . $day)->format('Y-m-d');

Upvotes: 1

goorj
goorj

Reputation: 443

could this work?

$start_timestamp = strtotime('2009-11-17');
$d1 = getdate($start_timestamp);

$end_timestamp = mktime(
    0,
    0,
    0,
    $d1['mon'] + 1 + floor($d1['mday']/16),   // 1 before the 16th, then 2
    15 * (1-floor($d1['mday']/16)),        //15 before the 16th, then 0
    $d1['year']
);
$end_date = date('Y-m-d', $end_timestamp);

Upvotes: 1

Related Questions