加入收藏 | 设为首页 | 会员中心 | 我要投稿 济南站长网 (https://www.0531zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

在PHP中添加小时:min:sec到date

发布时间:2021-04-01 01:07:45 所属栏目:MySql教程 来源:网络整理
导读:我想用日期添加hh:mm:ss.我该怎么做? 我试过以下但是当小时是字符串时它可以工作,但是当添加时间类似于MySQL日期时它不起作用. $new_time = date("Y-m-d H:i:s",strtotime('+5 hours')); 我正在尝试获得以下解决方案: $timeA= '2015-10-09 13:40:14';

我想用日期添加hh:mm:ss.我该怎么做?

我试过以下但是当小时是字符串时它可以工作,但是当添加时间类似于MySQL日期时它不起作用.

$new_time = date("Y-m-d H:i:s",strtotime('+5 hours'));

我正在尝试获得以下解决方案:

$timeA= '2015-10-09 13:40:14'; 

$timeB = '03:05:01';  // '0000-00-00 03:05:01'

输出:

$timeA + $timeB = 2015-10-09 16:45:15 ?

我该如何添加? 最佳答案 使用DateInterval()

$timeA = new DateTime('2015-10-09 13:40:14');
$timeB = new DateInterval('PT3H5M1S'); // '03:05:01'; 
$timeA->add($timeB);
echo $timeA->format('Y-m-d H:i:s');

您需要将时间分解为正确的DateInterval格式,但这很容易使用explode();

这可能是这样的:

$parts = array_map(function($num) {
    return (int) $num;
},explode(':','03:05:01'));

$timeA = new DateTime('2015-10-09 13:40:14');
$timeB = new DateInterval(sprintf('PT%uH%uM%uS',$parts[0],$parts[1],$parts[2]));
$timeA->add($timeB);
echo $timeA->format('Y-m-d H:i:s');

Demo

(编辑:济南站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读