DateInterval::createFromDateString

(PHP 5 >= 5.3.0, PHP 7, PHP 8)

DateInterval::createFromDateString Создаёт объект класса DateInterval из даты в относительном формате

Описание

Объектно-ориентированный стиль

publicstaticDateInterval::createFromDateString(string$datetime): DateInterval|false

Процедурный стиль

Использует парсер даты/времени, используемый в конструкторе DateTimeImmutable для создания объекта DateInterval из относительных частей разобранной строки.

Список параметров

datetime

Дата, состоящая из относительных временных фрагментов. В частности, для создания объекта DateInterval из частей, записанных в относительном формате, который поддерживается парсером в функциях DateTimeImmutable, DateTime и strtotime().

Чтобы использовать строку в формате ISO-8601, например P7D, необходимо использовать конструктор.

Возвращаемые значения

Возвращает новый объект класса DateInterval в случае успешного выполнения или false, если возникла ошибка.

Список изменений

ВерсияОписание
8.2.0 Только свойства from_string и date_string будут видны при создании объекта DateInterval с помощью этого метода.

Примеры

Пример #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";
?>

Результат выполнения приведённого примера:


449 2 70
1 -10

Пример #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) }
To Top