时间变量增加 1 小时

问题描述 投票:0回答:13

我有一个时间想添加一个小时:

$time = '10:09';

我已经尝试过:

$time = strtotime('+1 hour');

strtotime('+1 hour', $time);

$time = date('H:i', strtotime('+1 hour'));

但是以上都不起作用。

php datetime time
13个回答
118
投票

为我工作..

$timestamp = strtotime('10:09') + 60*60;

$time = date('H:i', $timestamp);

echo $time;//11:09

说明:

strtotime('10:09')
创建以秒为单位的数字时间戳,类似于
1510450372
。只需添加或删除您需要的秒数,然后使用
date()
将其转换回人类可读的格式。

$timestamp = strtotime('10:09') + 60*60; // 10:09 + 1 hour
$timestamp = strtotime('10:09') + 60*60*2; // 10:09 + 2 hours
$timestamp = strtotime('10:09') - 60*60; // 10:09 - 1 hour

time()
还创建一个数字时间戳,但现在是这样。您可以按照同样的方式使用它。

$timestamp = time() + 60*60; // now + 1 hour

30
投票

你可以这样做

    echo date('Y-m-d H:i:s', strtotime('4 minute'));
    echo date('Y-m-d H:i:s', strtotime('6 hour'));
    echo date('Y-m-d H:i:s', strtotime('2 day'));

17
投票

试试这个,它对我有用。

$time="10:09";
$time = date('H:i', strtotime($time.'+1 hour'));
echo $time;

16
投票
$time = '10:09';
$timestamp = strtotime($time);
$timestamp_one_hour_later = $timestamp + 3600; // 3600 sec. = 1 hour

// Formats the timestamp to HH:MM => outputs 11:09.
echo strftime('%H:%M', $timestamp_one_hour_later);
// As crolpa suggested, you can also do
// echo date('H:i', $timestamp_one_hour_later);

查看 PHP 手册中的 strtotime()strftime()date() 了解详细信息。

顺便说一句,在你的初始代码中,你需要添加一些引号,否则你会得到 PHP 语法错误:

$time = 10:09; // wrong syntax
$time = '10:09'; // syntax OK

$time = date(H:i, strtotime('+1 hour')); // wrong syntax
$time = date('H:i', strtotime('+1 hour')); // syntax OK

14
投票

2020更新

奇怪的是没有人建议 OOP 方式:

$date = new \DateTime(); //now
$date->add(new \DateInterval('PT3600S'));//add 3600s / 1 hour

$date = new \DateTime(); //now
$date->add(new \DateInterval('PT60M'));//add 60 min / 1 hour

$date = new \DateTime(); //now
$date->add(new \DateInterval('PT1H'));//add 1 hour

将其提取为字符串,格式为:

var_dump($date->format('Y-m-d H:i:s'));

4
投票

您可以尝试以下代码:

$time = '10:09';

echo date( 'H:i', strtotime( '+1 hour' , strtotime($time) ) );

3
投票

简单而智能的解决方案:

date("H:i:s", time()+3600);

1
投票

您可以使用:

$time = strtotime("10:09") + 3600;
echo date('H:i', $time);

date_add
http://www.php.net/manual/en/datetime.add.php


1
投票

为我工作 使用

DateTime::modify
date_modify
https://www.php.net/manual/en/datetime.modify.php

// Example:

$timestamp = 1680947903;
// Timestamp to datetime
$date = new \DateTime('@'. $timestamp );
$date->modify('+1 hour');

result


0
投票

我遇到了类似的问题,解决方法是说“小时”而不是“小时”。


0
投票

2024 使用 PHP 更新

<?php
//Connect to database
include ("config/connect_db.php");
//SQL Query from system Table
$sql = "SELECT * FROM system WHERE sysID='1'";

$result = $dbc->query($sql);
if ($result->num_rows > 0) {
  // output data of each row
  while($row = $result->fetch_assoc()) {
    $timeDST = $row["timeDST"];
if timeDST is in BST+1 (British Summer Time +1 Hour).
      if($timeDST == 'BST+1'){
          echo 
          date('Y-m-d H:i:s', strtotime('1 hour'));
      }
//if timeDST is in GMTMode (This is outside of British Summer Time)
      if($timeDST == 'GMT'){
          echo 
    date('Y-m-d H:i:s');  
      }
}
}
$dbc->close();
?>

我用它来将日期和时间插入到数据库表中。

<input type="hidden" name="entryDateTime" value="<?php
//Connect to database
include ("config/connect_db.php");
//SQL Query from system Table
$sql = "SELECT * FROM system WHERE sysID='1'";

$result = $dbc->query($sql);
if ($result->num_rows > 0) {
  // output data of each row
  while($row = $result->fetch_assoc()) {
    $timeDST = $row["timeDST"];
if timeDST is in BST+1 (British Summer Time +1 Hour).
      if($timeDST == 'BST+1'){
          echo 
          date('Y-m-d H:i:s', strtotime('1 hour'));
      }
//if timeDST is in GMTMode (This is outside of British Summer Time)
      if($timeDST == 'GMT'){
          echo 
    date('Y-m-d H:i:s');  
      }
}
}
$dbc->close();
?>">

-1
投票

谨防加3600!!由于unix时间戳格式在日期之前使用蛾,因此日期更改可能会出现问题。

例如2012-03-02 23:33:33 将成为 2014-01-13 13:00:00 通过添加 3600 更好地使用 mktime 和 date 函数,他们可以处理这个以及添加 25 小时等事情。


-2
投票

2021更新

为我工作..

$text = str_replace(':PM', '', '19:00:PM');   //19:00:PM  //Removes :PM
$text = str_replace(':AM', '', $text);   //Removes :AM
$time = strtotime($text);   //19:00
$startTime = date("H:i:A", strtotime('- 1 hours', $time));
$endTime = date("H:i:A", strtotime('+ 1 hours', $time));

输出:

echo $startTime; //18:00:PM
echo $endTime;  //20:00:PM
© www.soinside.com 2019 - 2024. All rights reserved.