PHP calc 时间差大于 24 小时

2024-05-10php开发问题
3

本文介绍了PHP calc 时间差大于 24 小时的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

当时间大于 24 小时时,计算时间差的最佳方法是什么.

示例

$time1 = '76:00:00';$time2 = '30:00:00';//结果应该是 46:00:00echo date('H:i:s', strtotime($time1) - strtotime($time2));

但这不能用这个来完成,因为它大于 24 小时.

我还在数据库中存储了这样的时间:33:30:00我如何在 php 中将其格式化为:33:30

解决方案

使用DateTimeDateInterval进行计算:

$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);回声 ($diff->days * 24 + $diff->h) .$diff->format(':%I:%S');

说明:无法直接在 DateInterval 上执行计算,因此您必须创建日期作为计算的基础.然后将两个不同的间隔添加到当前日期,并计算它们之间的差异.diff() 返回包含总天数的 DateInterval,您必须乘以 24 才能获得小时数,以及不等于完整天数的小时数.p>

时区应指定为 UTC 以避免夏令时问题.

What is the best way to calculate the difference in time, when time is greater than 24 hours.

Example

$time1 = '76:00:00';
$time2 = '30:00:00';

// result should be 46:00:00
echo date('H:i:s', strtotime($time1) - strtotime($time2));

But this could not be done with this because its greater then 24 hours.

Also in a database i've stored a time like this: 33:30:00 How in php could i format it to: 33:30

解决方案

Use DateTime and DateInterval to perform calculations:

$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');

Explanation: It's not possible to perform calculations directly on DateIntervals, so you have to create dates as a basis for calculations. Then add two different intervals to current dates, and calculate a difference between them. diff() returns DateInterval that contains total number of days, that you have to multiply by 24 to get hours, and hours that don't make full days.

EDIT: The timezone should be specified as UTC to avoid daylight saving time issues.

这篇关于PHP calc 时间差大于 24 小时的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

The End

相关推荐

PHP实现DeepL翻译API调用
DeepL的翻译效果还是很强大的,如果我们要用php实现DeepL翻译调用,该怎么办呢?以下是代码示例,希望能够帮到需要的朋友。 在这里需要注意,这个DeepL的账户和api申请比较难,不支持中国大陆申请,需要拥有香港或者海外信用卡才行,没账号的话,目前某宝可以...
2025-08-20 php开发问题
168

PHP通过phpspreadsheet导入Excel日期数据处理方法
PHP通过phpspreadsheet导入Excel日期,导入系统后,全部变为了4开头的几位数字,这是为什么呢?原因很简单,将Excel的时间设置问文本,我们就能看到该日期本来的数值,上图对应的数值为: 要怎么解决呢?进行数据转换就行,这里可以封装方法,或者用第三方的...
2024-10-23 php开发问题
287

mediatemple - 无法使用 codeigniter 发送电子邮件
mediatemple - can#39;t send email using codeigniter(mediatemple - 无法使用 codeigniter 发送电子邮件)...
2024-08-23 php开发问题
11

Laravel Gmail 配置错误
Laravel Gmail Configuration Error(Laravel Gmail 配置错误)...
2024-08-23 php开发问题
16

将 PHPMailer 用于 SMTP 的问题
Problem with using PHPMailer for SMTP(将 PHPMailer 用于 SMTP 的问题)...
2024-08-23 php开发问题
4

关于如何在 GoDaddy 服务器中使用 PHPMailer 设置 SMTP 的问题
Issue on how to setup SMTP using PHPMailer in GoDaddy server(关于如何在 GoDaddy 服务器中使用 PHPMailer 设置 SMTP 的问题)...
2024-08-23 php开发问题
17