(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.
datetime
Uma 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) }