Classe DateTime
A classe DateTime é a ferramenta principal para trabalhar com datas e hora no estilo OOP. Ela permite criar objetos de data/hora, modificá-los e formatar a saída.
Momento atual
Vamos criar um objeto DateTime
com a data e hora atuais:
<?php
$date = new DateTime();
?>
Data específica
Vamos criar um objeto DateTime com uma data especificada:
<?php
$date = new DateTime('2025-12-31');
?>
Data e hora específicas
Vamos criar um objeto DateTime
com uma data e hora especificadas:
<?php
$date = new DateTime('2025-12-31 12:59:59');
?>
Formatação da saída
A data criada pode ser exibida em um formato definido
usando o método format. Vamos fazer
isso para o momento atual:
<?php
$date = new DateTime();
echo $date->format('Y-m-d H:i:s');
?>
Resultado (irá mudar dependendo do momento da execução):
'2025-11-15 14:25:00'
Formatação de data especificada
Vamos formatar uma data especificada:
<?php
$date = new DateTime('2025-12-31');
echo $date->format('d.m.Y');
?>
Resultado da execução do código:
'31.12.2025'
Adição de intervalo
A adição de um intervalo a uma data
é feita através do método add:
<?php
$date = new DateTime('2025-05-15');
$interval = new DateInterval('P10D'); // 10 dias
$date->add($interval);
echo $date->format('Y-m-d');
?>
Resultado da execução do código:
'2025-05-25'
Subtração de intervalo
A subtração de um intervalo de uma data
é feita através do método sub:
<?php
$date = new DateTime('2025-05-15');
$interval = new DateInterval('P1M2D'); // 1 mês e 2 dias
$date->sub($interval);
echo $date->format('Y-m-d');
?>
Resultado da execução do código:
'2025-04-13'
Definindo uma nova data
É possível definir uma nova data para
o objeto DateTime. Isso é feito
através do método setDate:
<?php
$date = new DateTime();
$date->setDate(2025, 12, 31);
echo $date->format('Y-m-d');
?>
Resultado da execução do código:
'2025-12-31'
Definindo o horário
É possível definir um novo horário para
o objeto DateTime. Isso é feito
através do método setTime:
<?php
$date = new DateTime();
$date->setTime(15, 30, 0);
echo $date->format('H:i:s');
?>
Resultado da execução do código:
'15:30:00'
Comparação de datas
É possível comparar objetos com datas:
<?php
$date1 = new DateTime('2025-01-01');
$date2 = new DateTime('2025-02-01');
if ($date1 < $date2) {
echo '+++';
} else {
echo '---';
}
?>
Diferença entre datas
Usando o método diff é possível calcular
a diferença entre datas. A diferença
é retornada como um objeto
DateInterval:
<?php
$date1 = new DateTime('2023-01-01');
$date2 = new DateTime('2023-02-15');
$interval = $date1->diff($date2);
echo $interval->format('%m meses %d dias');
?>
Resultado da execução do código:
'1 meses 14 dias'
Fuso horário
Ao criar um objeto DateTime
é possível especificar o fuso horário:
<?php
$timeZone = new DateTimeZone('Europe/Moscow');
$date = new DateTime('2025-12-31 23:59:59', $timeZone);
echo $date->format('Y-m-d H:i:s e');
?>
Resultado da execução do código:
'2025-12-31 23:59:59 Europe/Moscow'
Veja também
-
classe
DateTimeImmutable,
que cria uma data imutável -
classe
DateInterval,
que define um intervalo de tempo -
classe
DateTimeZone,
que define um fuso horário