可能重复:
How to find number of days between two dates using php
我不想知道如何做到这一点。我想知道为什么它没有给出预期的结果。
我尝试计算格式为YYYY-mm-dd的两个日期之间的天数 使用此代码:
$day1 = strtotime($_REQUEST['start']);
$day2 = strtotime($_REQUEST['end']);
$nbOfDays = $day2 - $day1;
$nbOfDays = ceil($nbOfDays/60/60/24);
echo $nbOfDays;
问题是,当我计算2012-12-01和2012-12-31之间的差异时,它给了我30天(应该是31) 2012-11-01和2012-11-30之间的差异也是30(这是正确的!)
更新了纯信息:
我必须修改此代码(感谢Justin):
$day1 = new DateTime($_REQUEST['start']);
$day2 = new DateTime($_REQUEST['end']);
$interval = round(abs($day2->format('U') - $day1->format('U')) / (60*60*24));
echo $interval;
for:
$day1 = new DateTime($_REQUEST['start']);
$day2 = new DateTime($_REQUEST['end']);
$nb1 = $day2->format('U');
$nb2 = $day1->format('U');
$interval = round(abs($nb1 - $nb2) / (60*60*24));
echo $interval;
因为
$day2->format('U') - $day1->format('U')
等于0
所以最后,2012-12-31和2012-12-01之间的差异仍然是30. BUUUTTTT,2012-11-30和2012-11-01之间的差异是29,所以
echo $interval +1;
在任何情况下都给出正确的天数!
答案 0 :(得分:9)
您应该使用date_diff()
或其OO等效DateTime::diff()
来表示日期/时间差异。
$day1 = new DateTime($_REQUEST['start']);
$day2 = new DateTime($_REQUEST['end']);
$interval = $day1->diff($day2);
echo $interval->format('%d');
对于PHP 5.2版,您可以使用以下内容:
$day1 = new DateTime($_REQUEST['start']);
$day2 = new DateTime($_REQUEST['end']);
$interval = round(abs($day2->format('U') - $day1->format('U')) / (60*60*24));
echo $interval;
对于5.2之前的PHP版本,请使用strtotime()
以上公式:
$day1 = strtotime($_REQUEST['start']);
$day2 = strtotime($_REQUEST['end']);
$interval = round(abs($day2 - $day1) / (60*60*24));
echo $interval;