计算两个日期之间的天数

时间:2012-12-19 16:01:36

标签: php html date web

  

可能重复:
  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;

在任何情况下都给出正确的天数!

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;