比较两个日期结果0

时间:2016-05-12 09:41:14

标签: php date datetime

所以我目前正在制作一个小型的PHP应用程序,我需要比较两个日期以获得它们之间的天数。 我遗憾地不能使用datediff(),因为php版本是5.2。

我搜索了怎么做,我找到了很多答案,但我总是遇到同样的问题。当我在日期之间做出改变时,我总是得到0。

function date_diff($dateFrom, $dateTo) {
    echo $dateFrom->format('d-m-Y') . " : " . $dateTo->format('d-m-Y') . '<br/>';
    $diff = abs($dateTo-$dateFrom);

    return sprintf
    (
        "%d Days, %d Hours, %d Mins, %d Seconds",
        intval( $diff / 86400 ),
        intval( ( $diff % 86400 ) / 3600),
        intval( ( $diff / 60 ) % 60 ),
        intval( $diff % 60 )
    );
}

我目前使用此功能,参数在这里:

    while ($donnees = mysqli_fetch_array($res))
        $date = new DateTime($donnees['Date']);


    $date = date_create($date->format("Y-m-d"));
    $today = new DateTime();

    echo $utilDate->date_diff($date, $today);

我的$ date和$ today变量不为空,所以我不明白为什么这段代码不起作用。 有没有人有想法?

2 个答案:

答案 0 :(得分:2)

我认为$ dateTo和$ dateFrom是对象,你在$diff = abs($dateTo-$dateFrom);

中对它们做了减法

尝试$diff = abs($dateTo->getTimestamp()-$dateFrom->getTimestamp());

答案 1 :(得分:0)

您想使用diff运算符:

function date_diff($dateFrom, $dateTo) {
    echo $dateFrom->format('d-m-Y') . " : " . $dateTo->format('d-m-Y') . '<br/>';
    $diff = $dateNow->diff($dateTo);

    $day = $diff->format('%d');
    $hour = $diff->format('%h');
    $min = $diff->format('%i');
    $seconds = $diff->format('%s');

    return /*string involving above formats*/;
}