PHPerKaigi 2025

DateTimeInterface::format

DateTimeImmutable::format

DateTime::format

date_format

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

DateTimeInterface::format -- DateTimeImmutable::format -- DateTime::format -- date_formatRetorna a data formatada de acordo com um formato informado

Descrição

Estilo orientado a objetos

public DateTimeInterface::format(string $format): string
public DateTimeImmutable::format(string $format): string
public DateTime::format(string $format): string

Estilo procedural

Retorna a data formatada de acordo com um formato informado.

Parâmetros

object

Somente no estilo procedural: Um objeto DateTime retornado por date_create()

format

O formato da string de data resultante. Veja abaixo as opções de formatação. Existem também várias constantes de data predefinidas que podem ser usadas, por exemplo, DATE_RSS contém a string de formatação 'D, d M Y H:i:s'.

Os seguintes caracteres são reconhecidos na string do parâmetro format
Caractere format Descrição Exemplo de valores retornados
Dia --- ---
d Dia do mês, 2 digits com zeros à esquerda 01 a 31
D Uma representação textual de um dia, três letras Mon a Sun
j Dia do mês sem zeros à esquerda 1 a 31
l (lowercase 'L') Uma representação textual completa do dia da semana Sunday a Saturday
N Representação numérica ISO 8601 do dia da semana 1 (para segunda-feira) a 7 (para domingo)
S Sufixo ordinal inglês para o dia do mês, 2 caracteres st, nd, rd ou th. Funciona bem com j
w Representação numérica do dia da semana 0 (para domingo) a 6 (para sábado)
z O dia do ano (começando em 0) 0 a 365
Semana --- ---
W Número da semana do mês ISO 8601, semanas começando na segunda-feira Exemplo: 42 (a 42ª semana no ano)
Mês --- ---
F Uma representação textual completa do mês, como January ou March January a December
m Representação numérica de um mês, com zeros à esquerda 01 a 12
M Uma representação textual curta de um mês, três letras Jan a Dec
n Representação numérica de um mês, sem zeros à esquerda 1 a 12
t Número de dias em determinado mês 28 a 31
Ano --- ---
L Se é um ano bissexto 1 se for um ano bissexto, 0 caso contrário.
o Ano de numeração da semana ISO 8601. Tem o mesmo valor que Y, exceto que se o número da semana ISO (W) pertencer ao ano anterior ou seguinte, esse ano será usado. Exemplos: 1999 ou 2003
X Uma representação numérica completa expandida de um ano, pelo menos 4 dígitos, com - para anos AEC, e + para anos EC. Exemplos: -0055, +0787, +1999, +10191
x Uma representação numérica completa expandida se necessário, ou uma representação numérica completa padrão se possível (como Y). Pelo menos quatro dígitos. Anos AEC são prefixados com um -. Anos além de (e incluindo) 10000 são prefixados com um +. Exemplos: -0055, 0787, 1999, +10191
Y Uma representação numérica completa de um ano, pelo menos 4 dígitos, com - para anos AEC. Exemplos: -0055, 0787, 1999, 2003, 10191
y Uma representação de dois digitos do ano Exemplos: 99 ou 03
Hora --- ---
a Ante meridiem e Post meridiem em letras minúsculas am ou pm
A Ante meridiem e Post meridiem em letras maiúsculas AM ou PM
B Internet Time da Swatch 000 a 999
g Formato de 12 horas de uma hora sem zeros à esquerda 1 a 12
G Formato de 24 horas de uma hora sem zeros à esquerda 0 a 23
h Formato de 12 horas de uma hora com zeros à esquerda 01 a 12
H Formato de 24 horas de uma hora com zeros à esquerda 00 a 23
i Minutos com zeros à esquerda 00 to 59
s Segundos com zeros à esquerda 00 a 59
u Microssegundos. Note que date() sempre irá gerar 000000 uma vez que leva um parâmetro int, enquanto DateTimeInterface::format() suporta microssegundos se um objeto do tipo DateTimeInterface foi criado com microssegundos. Exemplo: 654321
v Millisegundos. A mesma nota se aplica como no u. Exemplo: 654
Fuso horário --- ---
e Identificador do fuso horário Exemplos: UTC, GMT, Atlantic/Azores
I (i maiúsculo) Se a data está ou não no horário de verão 1 se está no horário de verão, 0 caso contrário.
O Diferença para o horário de Greenwich (GMT) sem dois pontos entre horas e minutos Example: +0200
P Diferença para o horário de Greenwich (GMT) com dois pontos entre horas e minutos Exemplo: +02:00
p O mesmo que P, mas retorna Z em vez de +00:00 (disponível a partir do PHP 8.0.0) Exemplo: Z or +02:00
T Abreviação do fuso horário, se conhecido; ou o deslocamento GMT caso contrário. Exemplos: EST, MDT, +05
Z Deslocamento do fuso horário em segundos. O deslocamento para fusos a oeste de UTC é sempre negativo, e para aqueles a leste de UTC é sempre positivo. -43200 a 50400
Data/Hora completa --- ---
c Data ISO 8601 2004-02-12T15:19:21+00:00
r Data formatada » RFC 2822/» RFC 5322 Exemplo: Thu, 21 Dec 2000 16:01:07 +0200
U Segundos desde a Era Unix (1 de janeiro de 1970 00:00:00 GMT) Veja também time()

Caracteres não reconhecidos na string de formatação serão impressos como estão. O formato Z sempre retornará 0 ao usar gmdate().

Nota:

Uma vez que esta função só aceita timestamps int, o caractere de formato u só é útil ao usar a função date_format() com timestamps baseados no usuário criados com date_create().

Valor Retornado

Retorna a data formatada em caso de sucesso.

Registro de Alterações

Versão Descrição
8.2.0 Os caracteres de formatação X e x foram adicionados.
8.0.0 O caractere de formatação p foi adicionado.

Exemplos

Exemplo #1 Exemplo de DateTimeInterface::format()

Estilo orientado a objetos

<?php
$date
= new DateTimeImmutable('2000-01-01');
echo
$date->format('Y-m-d H:i:s');
?>

Estilo procedural

<?php
$date
= date_create('2000-01-01');
echo
date_format($date, 'Y-m-d H:i:s');
?>

O exemplo acima produzirá:

2000-01-01 00:00:00

Exemplo #2 Mais exemplos

<?php
// define o fuso horário padrão a ser usado.
date_default_timezone_set('UTC');

// agora
$date = new DateTimeImmutable();

// Imprime algo como: Wednesday
echo $date->format('l'), "\n";

// Imprime algo como: Wednesday 19th of October 2022 08:40:48 AM
echo $date->format('l jS \o\f F Y h:i:s A'), "\n";

/* usa as constantes no parâmetro format */
// Imprime algo como: Wed, 19 Oct 2022 08:40:48 +0000
echo $date->format(DateTimeInterface::RFC2822), "\n";
?>

Pode-se evitar que um caractere reconhecido na string de formação seja expandido escapando-o com uma barra invertida antes. Se o caractere com uma barra invertida já for uma sequência especial, pode-se escapar também a barra invertida.

Exemplo #3 Escapando caracteres ao formatar

<?php
$date
= new DateTimeImmutable();

// prints something like: Wednesday the 19th
echo $date->format('l \t\h\e jS');
?>

Para formatar datas em outras línguas, IntlDateFormatter::format() pode ser usado em vez do DateTimeInterface::format().

Notas

Este método não utiliza configurações baseadas no idioma. Toda a saída será em Inglês.

Veja Também

adicione uma nota

Notas Enviadas por Usuários (em inglês) 1 note

up
0
jurchiks101 at gmail dot com
13 days ago
If you want to get the week of year + year of said week, you need to use `format('o-W'), otherwise you can stumble into a non-obvious gotcha (unless you RTFM and memorised it, that is).
Using `Y` instead of `o` can result in incorrect year values in the case of the first or last week of the year (depending on if January 4th falls into said week or not), such as the first week of 2025 between 2024-12-30 and 2025-01-05 - `(new DateTime('2024-12-30'))->format('o-W')` will return the correct value of `2025-01` (as per ISO-8601 definition of week of year), while `format('Y-W')` will return `2024-01`.
Because of this, I would personally recommend avoiding using week of year anywhere unless absolutely necessary, as it is easy to make this mistake and never realise it.
To Top