DateInterval::createFromDateString

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

DateInterval::createFromDateString — Створює об'єкт класу DateInterval із дати у відносному форматі

Опис

Об'єктно-орієнтований стиль

public static DateInterval::createFromDateString(string $datetime): DateInterval|false

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

date_interval_create_from_date_string(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 Аналіз та розбір часових інтервалів

Loading...

Приклад #2 Розбір комбінацій та негативних інтервалів

Loading...

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

449 2 70

Приклад #3 Розбір спеціальних відносних часових інтервалів

Loading...

Результат виконання наведеного прикладу в 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)
}