Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/241.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
PHP计算时间差大于24小时_Php_Datetime_Time_Format_Date Formatting - Fatal编程技术网

PHP计算时间差大于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

当时间大于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
\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
。您可以检查此字段并在结果前添加
-