PHP计算时间差大于24小时
当时间大于24小时时,计算时间差的最佳方法是什么 示例PHP计算时间差大于24小时,php,datetime,time,format,date-formatting,Php,Datetime,Time,Format,Date Formatting,当时间大于24小时时,计算时间差的最佳方法是什么 示例 $time1 = '76:00:00'; $time2 = '30:00:00'; // result should be 46:00:00 echo date('H:i:s', strtotime($time1) - strtotime($time2)); 但这不能用它来完成,因为它超过了24小时 在一个数据库中,我还存储了这样一个时间:33:30:00 如何用php将其格式化为:33:30使用\DateTime和\DateInter
$time1 = '76:00:00';
$time2 = '30:00:00';
// result should be 46:00:00
echo date('H:i:s', strtotime($time1) - strtotime($time2));
但这不能用它来完成,因为它超过了24小时
在一个数据库中,我还存储了这样一个时间:33:30:00
如何用php将其格式化为:33:30使用
\DateTime
和\DateInterval
执行计算:
$date1 = new \DateTime('now', new DateTimeZone('UTC'));
$date2 = new \DateTime('now', new DateTimeZone('UTC'));
$time1 = new \DateInterval('PT76H');
$time2 = new \DateInterval('PT30H');
$date1->add($time1);
$date2->add($time2);
$diff = $date1->diff($date2);
echo ($diff->days * 24 + $diff->h) . $diff->format(':%I:%S');
说明:
无法直接在DateInterval
s上执行计算,因此必须创建日期作为计算的基础。然后将两个不同的时间间隔添加到当前日期,并计算它们之间的差异diff()
返回\DateInterval
,其中包含总天数,必须乘以24才能得到小时数,以及不等于完整天数的小时数
编辑:时区应指定为UTC,以避免夏令时问题。为什么这样存储时间?如果使用普通时间戳,则计算差异会容易得多。我认为您需要手动计算。在数据库中,字段类型为时间。因为我只需要时间而不需要日期。值是什么:'PT76H'和'PT30H'这些是时间间隔定义。看这里的例子:当一个时间比另一个时间大时,是否可能显示负值。是的。
$diff
中有一个invert
字段,如果差值为负值,则该字段为1
。您可以检查此字段并在结果前添加-
。