(PHP 5 >= 5.3.0, PHP 7, PHP 8)
DateInterval::createFromDateString — Cria um DateInterval de porções relativas da string
Estilo orientado a objetos
Estilo procedural
Utiliza o interpretador de data/hora como no construtor da classe DateTimeImmutable para criar um DateInterval a partir das partes relacionadas de uma string analisada.
datetimeUma data com porções relativas. Especificamente, os formatos relativos suportados pelo analisador utilizados em DateTimeImmutable, DateTime e strtotime() serão utilizados para construir o DateInterval.
Para usar um string no formato ISO-8601 como P7D, deve-se
usar o construtor DateInterval::__construct().
Retorna DateInterval em caso de sucesso.
Estilo procedural retorna false em caso de falha.
Apenas para API orientada a objetos: Se uma string de data/horário inválida for passada, uma exceção DateMalformedStringException é lançada.
| Versão | Descrição |
|---|---|
| 8.3.0 |
DateInterval::createFromDateString() agora lança
uma exceção DateMalformedStringException se uma
string inválida for passada. Anteriormente, retornava false
e um alerta era emitido.
A função date_interval_create_from_date_string() não foi
alterada.
|
| 8.2.0 |
Apenas as propriedades from_string e
date_string estarão visíveis quando um
DateInterval for criado com este método.
|
Exemplo #1 Analisando intervalos de datas válidos
<?php
// Cada conjunto de intervalos é igual.
$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');
?>
Exemplo #2 Analisando combinações e intervalos negativos
<?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";
?>O exemplo acima produzirá:
Exemplo #3 Analisando intervalos de data especiais
<?php
$i = DateInterval::createFromDateString('last day of next month');
var_dump($i);
$i = DateInterval::createFromDateString('last weekday');
var_dump($i);Saída do exemplo acima no 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"
}
A saída do exemplo acima no PHP 8 é semelhante a:
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)
}