Formatos de data e número

Com os formatos de data e hora e de número, você controla como seus dados aparecem em uma planilha. O app Planilhas Google oferece alguns formatos comuns, mas você também pode definir os seus.

Na interface do app Planilhas, você aplica formatos de número e data às células usando o menu Formato > Número. Na API Sheets, você define esses formatos usando uma chamada de método spreadsheets.batchUpdate para enviar um UpdateCellsRequest ou RepeatCellRequest.

Esta página descreve como definir novos padrões de formato de data e número, que podem ser incluídos na solicitação da API. O exemplo Definir um formato decimal ou de data e hora personalizado para um intervalo mostra como definir um padrão de formato usando a API. A renderização real do formato depende do locale da planilha. Este guia pressupõe que locale seja en_US. É possível determinar o locale de uma planilha lendo o SpreadsheetProperties com uma solicitação spreadsheets.get.

Sobre os valores de data e hora

O Planilhas, como a maioria dos outros aplicativos de planilhas, trata valores de data e hora como valores decimais. Isso permite que você realize operações aritméticas neles em fórmulas, para que você possa incrementar dias ou semanas, adicionar ou subtrair duas datas e horários e realizar outras operações semelhantes.

O app Planilhas usa uma forma de data de época que é comum em planilhas. A parte do número inteiro do valor (à esquerda do decimal) conta os dias desde 30 de dezembro de 1899. A parte fracionária (à direita do decimal) conta o tempo como uma fração de um dia. Por exemplo, 1º de janeiro de 1900 ao meio-dia é 2.5, 2 porque é dois dias depois de 30 de dezembro de 1899 e 0.5 porque meio-dia é metade de um dia. 1 de fevereiro de 1900 às 15h é 33.625.

O app Planilhas trata corretamente o ano de 1900 como um ano comum, não bissexto.

Padrões de formato de data e hora

Um padrão de formato de data e hora é uma string de substrings de token que, quando analisadas, são substituídas pelos elementos de data e hora correspondentes (como o mês ou a hora).

Tokens de formato de data e hora

A tabela a seguir define as substrings de token que podem ser usadas em um padrão de formato de data e hora. Um caractere + indica que o caractere anterior pode aparecer uma ou mais vezes e ainda corresponder ao padrão. Os caracteres não listados na tabela abaixo são tratados como literais e são exibidos sem alterações.

Token Descrição
h Hora do dia. Muda entre o formato de 12 e 24 horas, dependendo se um indicador AM ou PM está presente na string.
hh+ Igual ao anterior, mas com um 0 inicial para 1 a 9.
m Se o token não literal anterior for horas ou o subsequente for segundos, ele vai representar minutos na hora (sem um 0 inicial). Caso contrário, ele representa o mês do ano como um número (sem um 0 inicial).
M O mês do ano sem o zero à esquerda. Use esse token para declarar explicitamente um mês, em vez de um minuto, no seu padrão.
mm O mesmo que m, mas com um 0 inicial para os dois casos.
MM O mês do ano com um 0 à esquerda. Use esse token para declarar explicitamente um mês, em vez de um minuto, no seu padrão.
mmm Abreviação de três letras do mês (por exemplo, "Fev").
mmmm Nome completo do mês. mmmmmm+ também corresponde a isso.
mmmmm Primeira letra do mês (por exemplo, "J" para junho).
s Segundos no minuto sem zero à esquerda.
ss Segundos no minuto com zero à esquerda.
[h+] Número de horas decorridos em um período. O número de letras indica o número mínimo de dígitos (adiciona zeros à esquerda).
[m+] Número de minutos decorridos em um período. O número de letras indica o número mínimo de dígitos (adiciona zeros à esquerda).
[s+] Número de segundos decorridos em um período. O número de letras indica o número mínimo de dígitos (adiciona zeros à esquerda).
d Dia do mês, sem o zero à esquerda para números menores que 10.
dd Dia do mês, com um zero à esquerda para números menores que 10.
ddd Dia da semana, abreviação de três letras (por exemplo, "Seg").
dddd+ Dia da semana, nome completo.
y Ano com dois dígitos.
yy
yyy Ano com 4 dígitos.
yyyy+
a/p Mostra "a" para AM e "p" para PM. Também muda as horas para formato de 12 horas. Se a letra do token estiver em maiúsculas, a saída também será.
am/pm Como acima, mas exibe "AM" ou "PM" e sempre está em maiúsculas.
0 Décimos de segundo. É possível aumentar a precisão para dois dígitos com 00 ou três dígitos (milissegundos) com 000.
\ Trata o próximo caractere como um valor literal, e não qualquer significado especial que ele possa ter.
"text" Mostra o texto entre aspas como um literal.

Exemplos de formato de data e hora

Considerando a data e a hora Tuesday, April 5, 2016, 4:08:53.528 PM, a tabela a seguir mostra alguns exemplos de padrões e a renderização de data e hora correspondentes. A segunda seção da tabela mostra exemplos de formatos de tempo decorrido para um tempo decorrido de 3 hours, 13 minutes, 41.255 seconds:

Padrões de data e hora Tuesday, April 5, 2016, 4:08:53.528 PM
h:mm:ss.00 a/p 4:08:53.53 p
hh:mm A/P".M." 16h08
yyyy-mm-dd 2016-04-05
mmmm d \[dddd\] 5 de abril [terça-feira]
h PM, ddd mmm dd 16h, terça-feira, 5 de abril
dddd, m/d/yy at h:mm Terça-feira, 5/4/16, às 16h08
Padrões de tempo decorrido 3 hours, 13 minutes, 41.255 seconds
[hh]:[mm]:[ss].000 03:13:41.255
[mmmm]:[ss].000 0193:41.255

Padrões de formato de número

Um padrão de formato de número é uma string de substrings de token que, quando analisadas, são substituídas pelas representações numéricas correspondentes. Um padrão de formato de número pode ter até quatro seções, separadas por ponto e vírgula, que definem os formatos separados usados para números positivos, negativos, zero e texto (nessa ordem):

[POSITIVE FORMAT];[NEGATIVE FORMAT];[ZERO FORMAT];[TEXT FORMAT]

Não é necessário incluir as quatro seções em um formato. Se você incluir apenas uma seção, esse formato será usado para todos os valores. O uso de duas seções faz com que o primeiro formato seja aplicado a números positivos e zero, e o segundo formato a números negativos. O uso de três seções define formatos separados para números positivos, negativos e zero. Exemplo:

[NUMBER FORMAT]
[POSITIVE/ZERO FORMAT];[NEGATIVE FORMAT]
[POSITIVE FORMAT];[NEGATIVE FORMAT];[ZERO FORMAT]

No entanto, se houver duas ou mais seções e a última for um formato de texto, ela será tratada como o formato de texto, e as outras se comportarão como se houvesse uma seção a menos. Assim, ao incluir um formato de texto final, é possível definir formatos como:

[POSITIVE/ZERO FORMAT];[NEGATIVE FORMAT];[TEXT FORMAT]
[NUMBER FORMAT];[TEXT FORMAT]

A análise de um formato em seções ocorre antes de outras análises. Portanto, é possível incluir um formato de data ou hora como uma das seções, embora isso seja de utilidade limitada.

Tokens de formato de número

A tabela a seguir define as substrings de token que podem ser usadas em uma seção de formato para definir como representar os valores dessa seção.

Token Descrição
0 Representa um dígito no número. Se o dígito for um 0 insignificante, ele será renderizado como 0. Por exemplo, o formato de número 00.0 renderiza o número 3 como "03.0".
# Representa um dígito no número. Se o dígito for um 0 insignificante, ele não será renderizado. Por exemplo, o formato de número ##0 renderiza o número 12 como "12".
? Representa um dígito no número. Se o dígito for um 0 insignificante, ele será renderizado como um espaço. Isso é usado com frequência para alinhar o ponto decimal em uma coluna ao usar fontes de largura fixa. Por exemplo, o formato de número ???.??? renderiza o número 12,4 como: " 12.4 ".
. O primeiro ponto representa a vírgula no número. Os períodos subsequentes são renderizados como literais. Se você incluir um ponto decimal no formato, ele será renderizado sempre, mesmo para números inteiros. Por exemplo, #0.# renderiza o número 3 como "3.".
% Aparece como um literal, mas também faz com que os números sejam multiplicados por 100 antes de serem renderizados para tornar as porcentagens mais legíveis. Por exemplo, o formato de número #% renderiza o número 0,25 como "25%".
, Se ele aparecer entre caracteres de dois dígitos (0, # ou ?), o número inteiro será renderizado com separadores de agrupamento (agrupamento por milhares). Se ele seguir os caracteres de dígito, ele vai dimensionar os dígitos em mil por vírgula (por exemplo, o formato #0.0,, renderiza o número 12.200.000 como 12.2).
E- Renderiza o número no formato científico, com a formatação à esquerda do E usada para a parte não exponencial e a formatação à direita do E usada para a parte exponencial. E+ mostra um sinal + para expoentes positivos. E- mostra apenas um sinal para expoentes negativos. Se letras minúsculas forem usadas, a saída e também será em letras minúsculas. Por exemplo, o formato de número ##0.00#E+## renderiza o número 0,0000001 como "100.00E-9".
E+
e-
e+
/ Se ele aparecer entre caracteres de dois dígitos (0, # ou ?), ele vai tratar esses grupos de dígitos como um formato fracionário. Por exemplo, o formato de número 0 #/# renderiza o número 23,25 como 23 1/4. O denominador também pode ser um número inteiro literal. Nesse caso, ele impõe esse número como denominador. O formato de número 0 #/8 mostra o número 23,25 como 23 2/8. A parte fracionária não será renderizada se o numerador se tornar 0. O número 23,1 com o formato de número 0 #/3 é renderizado como 23 (porque o 0,1 é arredondado para 0/3). / não é compatível com o formato científico ou com um formato que tenha um ponto decimal nele.
* Isso é incluído para compatibilidade com os formatos de número do Microsoft Excel. No momento, ele é ignorado.
_ O token de sublinhado pula o próximo caractere e renderiza um espaço. Isso é usado para alinhar formatos de números em que o valor negativo está entre parênteses.
\ Trata o próximo caractere como um valor literal, e não como um significado especial. Por exemplo, o formato de número \#0 renderiza o número 10 como "#10".
"text" Mostra o texto entre aspas como um literal.
@ Se a célula tiver uma entrada de texto, o texto bruto será inserido nela. Não é compatível com nenhum dos outros caracteres especiais e não aparece para valores numéricos (que são mostrados como formato geral).
$ - + ( ) : space O Planilhas trata esses caracteres como literais e os exibe sem alterações.

Metainstruções

Além disso, cada uma das seções de formato pode ter metainstruções opcionais, envoltas em caracteres [], que precedem o formato e fornecem instruções adicionais. Há dois tipos de metainstrução, e uma seção pode usar os dois:

Instrução Descrição
[condition] Substitui a comparação positiva, negativa ou zero padrão da seção por outra expressão condicional. Por exemplo, [<100]”Low”;[>1000]”High”;000 renderiza a palavra "Baixo" para valores abaixo de 100, "Alto" para valores acima de 1000 e um número de três dígitos (com 0s iniciais) para qualquer valor entre esses valores. As condições só podem ser aplicadas aos dois primeiros subformatos. Se um número corresponder a mais de um, ele vai usar o primeiro. Se houver um terceiro formato, ele será usado para "tudo o mais". Caso contrário, se um número não corresponder a nenhum formato, ele será renderizado como todos os "#" preenchendo a largura da célula. Se ele existir, o quarto formato será sempre usado para texto.
[Color] or [Color#] Faz com que qualquer valor renderizado por esse subformato apareça com a cor de texto especificada. Os valores válidos para Color são preto, azul, ciano, verde, magenta, vermelho, branco ou amarelo. Os valores válidos para "#" em Color# são 1 a 56. Esta paleta de cores mostra uma lista das cores que correspondem a cada número. As cores de formato de número substituem todas as cores inseridas pelo usuário na célula, mas não substituem as cores definidas pela formatação condicional.

Exemplos de formato de número

A tabela a seguir mostra alguns exemplos de padrões e a renderização de números formatados correspondentes:

Número Padrão Valor formatado
12345.125 ####.# 12345.1
12,34 000.0000 012.3400
12 #.0# 12.0
5,125 # ???/??? 5 1/8
12000 #,### 12.000
1230000 0.0,,"M" 1,2 milhão
1234500000 0.00e+00 1,23e+09
123114.15115
MyText
###0.000;"TEXT: "_(@_) 123114.151
TEXT: MyText
1234
-1234
0
MyText
[Blue]#,##0;[Red]#,##0;[Green]0.0;[Magenta]_(@_) 1.234
1.234
0.0
MyText
1005
32
527
[>1000]"HIGH";[Color43][<=200]"LOW";0000 HIGH
LOW
0527