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

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

发布时间:2021-04-01 07:18:02 所属栏目:编程 来源:网络整理
导读:我想用日期添加hh:mm:ss.我该怎么做? 我试过以下可是当小时是字符串时它可以事变,可是当添加时刻相同于MySQL日期时它不起浸染. $new_time = date("Y-m-d H:i:s",strtotime('+5 hours')); 我正在实行得到以下办理方案: $timeA= '2015-10-09 13:40:14'; $t

我想用日期添加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

(编辑:湖南网)

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

    热点阅读