[英]How to get absolute date difference between two dates in PHP?
我看到在这个问题上有其他语言的其他帖子,但我找不到PHP的一个。 我不是在寻找两个日期时间之间的差异,而是在多少天不同。 例如:
2011-08-06 14:05:28
和
2011-08-07 08:46:28
不太然后有一天分开,但我想一个函数,会告诉我他们的日子是相隔一天,即会返回值1
这两个日期,并返回一个值2
以下日期为例:
2011-08-06 23:05:28
和
2011-08-08 01:46:28
真的,我猜它一定很容易,但我之前的日期工作并不多。
哦,还有一个约束,我需要与PHP 5.2兼容的东西,所以不能使用DateTime::diff
。
编辑:改为澄清我确实需要一个数字返回值,对不起:)
如果我正确地解释了这个问题,你需要GregorianToJD或mysql to_days
两个函数都返回特定日期的朱利安日 ,这基本上是“第0天”以来的天数。
$date1 = "2011-08-06 14:05:28";
$date2 = "2011-08-07 08:46:28";
if(date('Ymd', strtotime($date1)) == date('Ymd', strtotime($date2)))
{
// Same day!
}
更新
如果你真的想要几天之间的天数,我建议你更新到PHP 5.3。 计算天数可能相当困难,特别是如果您希望能够处理不同年份的天数。
$days = abs(date('z', strtotime($date1)) - date('z', strtotime($date2)));
这是我能做的最好的,但它要求 $date1
和$date2
在同一年。
我会尝试这样的东西(主要使用时间戳):
/**
* @param string $date1
* @param string $date2
* @return int
* Number of days between the two dates.
*/
function date_diff_days($date1, $date2) {
// Ignore the time part and convert the date part to timestamp.
$date1 = substr($date1, 0, 10);
$date1 = strtotime($date1 . ' 00:00:00');
$date2 = substr($date2, 0, 10);
$date2 = strtotime($date2 . ' 00:00:00');
// Compute the difference in seconds.
$diff_secs = abs($date1 - $date2);
// Convert the difference to days.
$diff_days = ceil($diff_secs / (60 * 60 * 24));
return $diff_days;
}
我用你的测试用例尝试了它,它就像你想要的那样工作。 如果您想要进行任何更改,可以编辑该功能。 希望能帮助到你!
$date1 = "2011-08-06 14:05:28";
$date2 = "2011-08-07 08:46:28";
if(date("Ymd",strtotime($date1)) == date("Ymd",strtotime($date2)) {
// they match
} else {
// calculate the difference
$diff = ceil(abs(strtotime($date1)-strtotime($date2))/86400);
}
$secondsApart = strtotime( '2011-08-07 08:46:28' ) -
strtotime( '2011-08-06 14:05:28' );
现在,您可以根据以下内容计算任何其他值:
$hoursApart = round( $secondsApart / 3600 );
$daysApart = round( $secondsApart / 86400 );
...
你也可以使用floor()或ceil()代替round(),如果这更适合你的需要。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.