Reputation: 138
I start with two dates:
$endDate = '2013-11-30 18:30:00';
$beginDate = '2013-10-31 18:30:00';
Then, I took date difference using following code:
$diff = abs(strtotime($endDate) - strtotime($beginDate));
Next, I check the date difference by
$days = $diff / (60*60*24);
However, it returns a fractional day, such as 30.041666666667
. I don't want to get this fractional. Why this happening? This problem occurs in some cases only.
Upvotes: 0
Views: 107
Reputation: 4331
Try this :
$date1 = new DateTime("2013-11-21 12:59:00");
$date2 = new DateTime("2013-11-21 13:01:00");
$interval = $date1->diff($date2);
echo "DIFF: ".$interval->format("%Y-%m-%d %H:%i:%s");
Visit the link for details
Upvotes: 1
Reputation: 1007
you can also use mktime()
function for calculate diff.
<?php
$endDate = '2013-11-30 18:30:00';
$endDateTemp = explode(' ', $endDate);
$endDateArr1 = explode('-', $endDateTemp[0]);
$endDateArr2 = explode(':', $endDateTemp[1]);
$endTimestamp = mktime($endDateArr2[0], $endDateArr2[1], $endDateArr2[2], $endDateArr1[1], $endDateArr1[2], $endDateArr1[0]);
$beginDate = '2013-10-31 18:30:00';
$beginDateTemp = explode(' ', $beginDate);
$beginDateArr1 = explode('-', $beginDateTemp[0]);
$beginDateArr2 = explode(':', $beginDateTemp[1]);
$beginTimestamp = mktime($beginDateArr2[0], $beginDateArr2[1], $beginDateArr2[2], $beginDateArr1[1], $beginDateArr1[2], $beginDateArr1[0]);
$diff = $endTimestamp - $beginTimestamp;
$day = $diff/(24*60*60);
?>
Upvotes: 1