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)
}