我有一个PHP日期,格式为2013-01-22
,我想以相同的格式获取明天的日期,例如2013-01-23
。
这在PHP中如何实现?
使用DateTime
$datetime = new DateTime('tomorrow');
echo $datetime->format('Y-m-d H:i:s');
或:
$datetime = new DateTime('2013-01-22');
$datetime->modify('+1 day');
echo $datetime->format('Y-m-d H:i:s');
或者:$datetime = new DateTime('2013-01-22');
$datetime->add(new DateInterval("P1D"));
echo $datetime->format('Y-m-d H:i:s');
或在 PHP 5.4+ 版本中:
echo (new DateTime('2013-01-22'))->add(new DateInterval("P1D"))
->format('Y-m-d H:i:s');
$tomorrow = date("Y-m-d", strtotime('tomorrow'));
或者 $tomorrow = date("Y-m-d", strtotime("+1 day"));
帮助链接:STRTOTIME()
-1天
。 - bwoogie由于您使用了strtotime标签,您可以像这样使用它来进行+1 day
修改:
$tomorrow_timestamp = strtotime('+1 day', strtotime('2013-01-22'));
话虽如此,更好的解决方案是使用DateTime。
<? php
//1 Day = 24*60*60 = 86400
echo date("d-m-Y", time()+86400);
?>
echo date ('Y-m-d',strtotime('+1 day', strtotime($your_date)));
使用DateTime
:
获取明天的时间:
$d = new DateTime('+1day');
$tomorrow = $d->format('d/m/Y h.i.s');
echo $tomorrow;
结果:2017年6月28日 08:13:20
要从一个日期获取明天:
$d = new DateTime('2017/06/10 08.16.35 +1day')
$tomorrow = $d->format('d/m/Y h.i.s');
echo $tomorrow;
结果:2017年11月6日08:16:35
希望能帮到你!
/**
* get tomorrow's date in the format requested, default to Y-m-d for MySQL (e.g. 2013-01-04)
*
* @param string
*
* @return string
*/
public static function getTomorrowsDate($format = 'Y-m-d')
{
$date = new DateTime();
$date->add(DateInterval::createFromDateString('tomorrow'));
return $date->format($format);
}
虽然看起来很奇怪,但这段代码可以完美地运行:date_create( '2016-02-01 + 1 day' );
echo date_create( $your_date . ' + 1 day' )->format( 'Y-m-d' );
应该就可以了。
这是一个可工作的函数
function plus_one_day($date){
$date2 = formatDate4db($date);
$date1 = str_replace('-', '/', $date2);
$tomorrow = date('Y-m-d',strtotime($date1 . "+1 days"));
return $tomorrow; }
$date = '2013-01-22';
$time = strtotime($date) + 86400;
echo date('Y-m-d', $time);
其中86400是一天的秒数。