(PHP 5 >= 5.3.0, PHP 7, PHP 8)
DateInterval::createFromDateString — Создаёт объект класса DateInterval из даты в относительном формате
Объектно-ориентированный стиль
Процедурный стиль
Метод использует парсеры даты и времени, которые в конструкторе класса DateTimeImmutable создают интервал DateInterval из обозначений времени в относительном формате.
datetime
Дата из обозначений времени в относительном формате. Метод создаёт интервал DateInterval из фрагментов времени в относительном формате, который поддерживается парсером классов DateTimeImmutable, DateTime и функции strtotime()
Метод не поддерживает интервалы в формате P7D
,
спецификацию которого определяет стандарт ISO-8601,
в отличие от метода DateInterval::__construct().
Метод возвращает новый экземпляр класса DateInterval, если выполнился успешно.
Процедурный стиль возвращает false
, если возникла ошибка.
Только для объектно-ориентированного API-интерфейса: Метод выбрасывает исключение DateMalformedStringException, если передали недопустимую строку с датой и временем.
Версия | Описание |
---|---|
8.3.0 |
Метод DateInterval::createFromDateString() теперь выбрасывает
исключение DateMalformedStringException,
если передали строку в недопустимом формате. Раньше метод возвращал значение false
и выдавал предупреждение.
Функция date_interval_create_from_date_string()
не изменилась.
|
8.2.0 |
Объект интервала DateInterval, который создаётся этим методом,
показывает только свойства from_string и date_string .
|
Пример #1 Пример разбора допустимых интервалов времени
<?php
// Интервалы в каждом примере эквивалентны
$i = new DateInterval('P1D');
$i = DateInterval::createFromDateString('1 day');
$i = new DateInterval('P2W');
$i = DateInterval::createFromDateString('2 weeks');
$i = new DateInterval('P3M');
$i = DateInterval::createFromDateString('3 months');
$i = new DateInterval('P4Y');
$i = DateInterval::createFromDateString('4 years');
$i = new DateInterval('P1Y1D');
$i = DateInterval::createFromDateString('1 year + 1 day');
$i = new DateInterval('P1DT12H');
$i = DateInterval::createFromDateString('1 day + 12 hours');
$i = new DateInterval('PT3600S');
$i = DateInterval::createFromDateString('3600 seconds');
?>
Пример #2 Разбор комбинаций и отрицательных интервалов
<?php
$i = DateInterval::createFromDateString('62 weeks + 1 day + 2 weeks + 2 hours + 70 minutes');
echo $i->format('%d %h %i'), "\n";
$i = DateInterval::createFromDateString('1 year - 10 days');
echo $i->format('%y %d'), "\n";
?>
Результат выполнения приведённого примера:
Пример #3 Разбор относительных интервалов времени
<?php
$i = DateInterval::createFromDateString('last day of next month');
var_dump($i);
$i = DateInterval::createFromDateString('last weekday');
var_dump($i);
?>
Результат выполнения приведённого примера в PHP 8.2:
object(DateInterval)#1 (2) { ["from_string"]=> bool(true) ["date_string"]=> string(22) "last day of next month" } object(DateInterval)#2 (2) { ["from_string"]=> bool(true) ["date_string"]=> string(12) "last weekday" }
Результат выполнения приведённого примера в PHP 8 аналогичен:
object(DateInterval)#1 (16) { ["y"]=> int(0) ["m"]=> int(1) ["d"]=> int(0) ["h"]=> int(0) ["i"]=> int(0) ["s"]=> int(0) ["f"]=> float(0) ["weekday"]=> int(0) ["weekday_behavior"]=> int(0) ["first_last_day_of"]=> int(2) ["invert"]=> int(0) ["days"]=> bool(false) ["special_type"]=> int(0) ["special_amount"]=> int(0) ["have_weekday_relative"]=> int(0) ["have_special_relative"]=> int(0) } object(DateInterval)#2 (16) { ["y"]=> int(0) ["m"]=> int(0) ["d"]=> int(0) ["h"]=> int(0) ["i"]=> int(0) ["s"]=> int(0) ["f"]=> float(0) ["weekday"]=> int(0) ["weekday_behavior"]=> int(0) ["first_last_day_of"]=> int(0) ["invert"]=> int(0) ["days"]=> bool(false) ["special_type"]=> int(1) ["special_amount"]=> int(-1) ["have_weekday_relative"]=> int(0) ["have_special_relative"]=> int(1) }