我正在尝试编写一个可以计算两个日期之间的天数的函数。我目前有以下内容,但它给了我一些意想不到的结果:
function dayCount($from, $to) {
$first_date = strtotime($from);
$second_date = strtotime($to);
$offset = $second_date-$first_date;
return floor($offset/60/60/24);
}
print dayCount($s, $e).' Days';
几个正确的例子:
$s = '18-03-2016';
$e = '25-03-2016';
输出:7 Days
- 正确
$s = '03-02-2016';
$e = '06-02-2016';
输出:3 Days
- 正确
$s = '06-04-2016';
$e = '27-04-2016';
输出:21 Days
- 正确
但是,如果我的日期在2个月之间交叉,有时它是正确的,有时候会显示更少的日期:
$s = '25-03-2016';
$e = '01-04-2016';
输出:6 Days
- 应为7天
$s = '23-02-2016';
$e = '01-03-2016';
输出:7 Days
- 正确
答案 0 :(得分:8)
请使用currentDB
功能获取两个日期之间的日期。
diff
答案 1 :(得分:6)
请使用像这样的date_diff函数
<?php
$date1=date_create("2013-03-15");
$date2=date_create("2013-12-12");
$diff=date_diff($date1,$date2);
echo $diff->format("%R%a days");
?>
希望这对你有帮助。
答案 2 :(得分:3)
你也可以使用它(对于PHP 5.1.5及以上版本而不使用date_diff()):
function dayCount($from, $to) {
$first_date = strtotime($from);
$second_date = strtotime($to);
$days_diff = $second_date - $first_date;
return date('d',$days_diff);
}
print dayCount($s, $e).' Days';