array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'ru', ), 'this' => array ( 0 => 'datetime.modify.php', 1 => 'DateTime::modify', ), 'up' => array ( 0 => 'class.datetime.php', 1 => 'DateTime', ), 'prev' => array ( 0 => 'datetime.getlasterrors.php', 1 => 'DateTime::getLastErrors', ), 'next' => array ( 0 => 'datetime.set-state.php', 1 => 'DateTime::__set_state', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'ru', 'path' => 'reference/datetime/datetime/modify.xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(PHP 5 >= 5.2.0, PHP 7, PHP 8)
DateTime::modify -- date_modify — Изменение временной метки
Объектно-ориентированный стиль
Процедурный стиль
Изменяет метку времени объекта DateTime путём добавления или вычитания времени в формате, принятом для функции DateTimeImmutable::__construct().
object
Только для процедурного стиля: объект DateTime, который возвращает функция date_create(). Функция изменяет этот объект.
modifier
Строка даты и времени. Объяснение корректных форматов дано в разделе Форматы даты и времени.
Возвращает модифицированный объект DateTime для применения в цепи методов или false
, если возникла ошибка.
Только для объектно-ориентированного API: Если передана строка с недопустимой датой/временем, будет выброшено исключение DateMalformedStringException.
Версия | Описание |
---|---|
8.3.0 | Теперь вместо предупреждения в методе DateTime::modify() выбрасывается исключение DateMalformedStringException, если передана недопустимая строка. Функция date_modify() не была изменена. |
Пример #1 Пример использования DateTime::modify()
Объектно-ориентированный стиль
<?php
$date = new DateTime('2006-12-12');
$date->modify('+1 day');
echo $date->format('Y-m-d');
?>
Процедурный стиль
<?php
$date = date_create('2006-12-12');
date_modify($date, '+1 day');
echo date_format($date, 'Y-m-d');
?>
Результат выполнения приведённых примеров:
2006-12-13
Пример #2 Будьте осторожны при добавлении и вычитании месяцев
<?php
$date = new DateTime('2000-12-31');
$date->modify('+1 month');
echo $date->format('Y-m-d') . "\n";
$date->modify('+1 month');
echo $date->format('Y-m-d') . "\n";
?>
Результат выполнения приведённого примера:
2001-01-31 2001-03-03
Пример #3 Поддерживаются все форматы даты и времени
<?php
$date = new DateTime('2020-12-31');
$date->modify('July 1st, 2023');
echo $date->format('Y-m-d H:i') . "\n";
$date->modify('Monday next week');
echo $date->format('Y-m-d H:i') . "\n";
$date->modify('17:30');
echo $date->format('Y-m-d H:i') . "\n";
?>
Результат выполнения приведённого примера:
2023-07-01 00:00 2023-07-03 00:00 2023-07-03 17:30