日期计算的问题

来源:互联网 发布:网络如何发布广告赚钱 编辑:程序博客网 时间:2024/06/06 00:57

最近工作上遇到的问题:1月1日的下一个月是2月1日,1月31日的下一个月是几号呢?

针对这个问题,我的需求自然是2月28日或2月29日,原先想的简单,就是加一个月:

<?php$d = new DateTime('2017-01-31');$d->add(new DateInterval('P1M'));echo $d->format('Y-m-d'); // 2017-03-03?>

结果跑到3月份去了,php的DateTime并不会产生想要的结果。接下来自然要去优化它(思路是月份加2,日期设置成1号,再减一天,就是下个月最后一天了):

$d = new DateTime('2017-01-31');$d->setDate($d->format('Y'), $d->format('n') + 2, 1);$d->sub(new DateInterval('P1D'));echo $d->format('Y-m-d') . PHP_EOL; // 2017-02-28

已经得到想要的结果过了,大功告成!

注意:当遇到11月、12月时月份加2就是13、14了,setDate会相应的自动增加年份的

原创粉丝点击