Compartilhar via


Get-Date

Obtém a data e hora atuais.

Syntax

Get-Date
   [[-Date] <DateTime>]
   [-Year <Int32>]
   [-Month <Int32>]
   [-Day <Int32>]
   [-Hour <Int32>]
   [-Minute <Int32>]
   [-Second <Int32>]
   [-Millisecond <Int32>]
   [-DisplayHint <DisplayHintType>]
   [-Format <String>]
   [-AsUTC]
   [<CommonParameters>]
Get-Date
   [[-Date] <DateTime>]
   [-Year <Int32>]
   [-Month <Int32>]
   [-Day <Int32>]
   [-Hour <Int32>]
   [-Minute <Int32>]
   [-Second <Int32>]
   [-Millisecond <Int32>]
   [-DisplayHint <DisplayHintType>]
   -UFormat <String>
   [<CommonParameters>]
Get-Date
   -UnixTimeSeconds <Int64>
   [-Year <Int32>]
   [-Month <Int32>]
   [-Day <Int32>]
   [-Hour <Int32>]
   [-Minute <Int32>]
   [-Second <Int32>]
   [-Millisecond <Int32>]
   [-DisplayHint <DisplayHintType>]
   [-Format <String>]
   [-AsUTC]
   [<CommonParameters>]
Get-Date
   -UnixTimeSeconds <Int64>
   [-Year <Int32>]
   [-Month <Int32>]
   [-Day <Int32>]
   [-Hour <Int32>]
   [-Minute <Int32>]
   [-Second <Int32>]
   [-Millisecond <Int32>]
   [-DisplayHint <DisplayHintType>]
   -UFormat <String>
   [<CommonParameters>]

Description

O Get-Date cmdlet obtém um objeto DateTime que representa a data atual ou uma data especificada. Get-Date pode formatar a data e a hora em vários formatos .NET e UNIX. Você pode usar Get-Date para gerar uma cadeia de caracteres de data ou hora e, em seguida, enviar a cadeia de caracteres para outros cmdlets ou programas.

Get-Date usa as configurações de cultura atuais do sistema operacional para determinar como a saída é formatada. Para exibir as configurações do computador, use (Get-Culture).DateTimeFormat.

Exemplos

Exemplo 1: Obter a data e a hora atuais

Neste exemplo, Get-Date exibe a data e a hora do sistema atuais. A saída está nos formatos long-date e long-time.

Get-Date

Tuesday, June 25, 2019 14:53:32

Exemplo 2: Obter elementos da data e hora atuais

Este exemplo mostra como usar Get-Date para obter o elemento de data ou hora. O parâmetro usa os argumentos Date, Time ou DateTime.

Get-Date -DisplayHint Date

Tuesday, June 25, 2019

Get-Date usa o parâmetro DisplayHint com o argumento Date para obter apenas a data.

Exemplo 3: Obter a data e a hora com um especificador de formato .NET

Neste exemplo, um especificador de formato .NET é usado para personalizar o formato da saída. A saída é um objeto String .

Get-Date -Format "dddd MM/dd/yyyy HH:mm K"

Tuesday 06/25/2019 16:17 -07:00

Get-Date usa o parâmetro Format para especificar vários especificadores de formato.

Os especificadores de formato .NET usados neste exemplo são definidos da seguinte maneira:

Especificador Definição
dddd Dia da semana – nome completo
MM Número do mês
dd Dia do mês – 2 dígitos
yyyy Ano no formato de 4 dígitos
HH:mm Tempo no formato de 24 horas - sem segundos
K Deslocamento de fuso horário da Coordenada de Tempo Universal (UTC)

Para obter mais informações sobre especificadores de formato .NET, consulte Cadeias de caracteres de formato de data e hora personalizadas.

Exemplo 4: Obter a data e a hora com um especificador UFormat

Neste exemplo, vários especificadores de formato UFormat são usados para personalizar o formato da saída. A saída é um objeto String .

Get-Date -UFormat "%A %m/%d/%Y %R %Z"

Tuesday 06/25/2019 16:19 -07

Get-Date usa o parâmetro UFormat para especificar vários especificadores de formato.

Os especificadores de formato UFormat usados neste exemplo são definidos da seguinte maneira:

Especificador Definição
%A Dia da semana – nome completo
%m Número do mês
%d Dia do mês – 2 dígitos
%Y Ano no formato de 4 dígitos
%R Tempo no formato de 24 horas - sem segundos
%Z Deslocamento de fuso horário da Coordenada de Tempo Universal (UTC)

Para obter uma lista de especificadores de formato UFormat válidos, consulte a seção Anotações .

Exemplo 5: Obter uma data do dia do ano

Neste exemplo, uma propriedade é usada para obter o dia numérico do ano.

O calendário gregoriano tem 365 dias, exceto por anos bissextos que têm 366 dias. Por exemplo, 31 de dezembro de 2020 é o dia 366.

(Get-Date -Year 2020 -Month 12 -Day 31).DayOfYear

366

Get-Date usa três parâmetros para especificar a data: Ano, Mês e Dia. O comando é encapsulado com parênteses para que o resultado seja avaliado pela propriedade DayofYear .

Exemplo 6: Verificar se uma data é ajustada para o horário de verão

Este exemplo usa um método booliano para verificar se uma data é ajustada pelo horário de verão.

$DST = Get-Date
$DST.IsDaylightSavingTime()

True

Uma variável armazena $DST o resultado de Get-Date. $DST usa o método IsDaylightSavingTime para testar se a data é ajustada para o horário de verão.

Exemplo 7: Converter a hora atual em hora UTC

Neste exemplo, a hora atual é convertida em hora UTC. O deslocamento UTC para a localidade do sistema é usado para converter a hora. Uma tabela na seção Anotações lista os especificadores de formato UFormat válidos.

Get-Date -UFormat "%A %B/%d/%Y %T %Z"
$Time = Get-Date
$Time.ToUniversalTime()

Wednesday June/26/2019 10:45:26 -07

Wednesday, June 26, 2019 17:45:26

Get-Date usa o parâmetro UFormat com especificadores de formato para exibir a data e a hora do sistema atual. O especificador de formato %Z representa o deslocamento UTC de -07.

A $Time variável armazena a data e a hora do sistema atuais. $Time usa o ToUniversalTime() método para converter a hora com base no deslocamento UTC do computador.

Exemplo 8: Create um carimbo de data/hora

Neste exemplo, um especificador de formato cria um objeto String de carimbo de data/hora para um nome de diretório. O carimbo de data/hora inclui a data, a hora e o deslocamento UTC.

$timestamp = Get-Date -Format o | ForEach-Object { $_ -replace ":", "." }
New-Item -Path C:\Test\$timestamp -Type Directory

Directory: C:\Test

Mode                LastWriteTime         Length Name
----                -------------         ------ ----
d-----         6/27/2019    07:59                2019-06-27T07.59.24.4603750-07.00

A $timestamp variável armazena os resultados de um Get-Date comando. Get-Date usa o parâmetro Format com o especificador de formato de minúsculas o para criar um objeto String de carimbo de data/hora. O objeto é enviado pelo pipeline para ForEach-Object. Um ScriptBlock contém a $_ variável que representa o objeto de pipeline atual. A cadeia de caracteres de carimbo de data/hora é delimitada por dois-pontos que são substituídos por períodos.

New-Item usa o parâmetro Path para especificar o local para um novo diretório. O caminho inclui a $timestamp variável como o nome do diretório. O parâmetro Type especifica que um diretório é criado.

Exemplo 9: Converter um carimbo de data/hora do Unix

Esse exemplo converte o horário do Unix (representado pelo número de segundos desde 1970-01-01 0:00:00) para DateTime.

Get-Date -UnixTimeSeconds 1577836800

Wednesday, January 01, 2020 12:00:00 AM

Exemplo 10: retornar um valor de data interpretado como UTC

Este exemplo mostra como interpretar um valor de data como seu equivalente UTC. Por exemplo, esse computador é definido como Hora Padrão do Pacífico. Por padrão, Get-Date retorna valores para esse fuso horário. Use o parâmetro AsUTC para converter o valor no tempo equivalente UTC.

PS> Get-TimeZone

Id                         : Pacific Standard Time
DisplayName                : (UTC-08:00) Pacific Time (US & Canada)
StandardName               : Pacific Standard Time
DaylightName               : Pacific Daylight Time
BaseUtcOffset              : -08:00:00
SupportsDaylightSavingTime : True

PS> (Get-Date -Date "2020-01-01T00:00:00").Kind
Unspecified

PS> Get-Date -Date "2020-01-01T00:00:00"

Wednesday, January 1, 2020 12:00:00 AM

PS> (Get-Date -Date "2020-01-01T00:00:00" -AsUTC).Kind
Utc

PS> Get-Date -Date "2020-01-01T00:00:00" -AsUTC

Wednesday, January 1, 2020 8:00:00 AM

Exemplo 11: Mostrar cultura invariável

O ToString() converte um objeto DateTimeem String usando a configuração de cultura atual. No entanto, a interpretação da expressão do PowerShell sempre usa a configuração de cultura invariável.

Por exemplo, em um sistema com a en-US cultura em vigor, o ToString() método formata a data usando as en-US configurações de cultura.

# Get date using current culture en-US
(Get-Date 2024-03-19).ToString()

3/19/2024 12:00:00 AM

# Get date using invariant culture
"$(Get-Date 2024-03-19)"

03/19/2024 00:00:00

Parâmetros

-AsUTC

Converte o valor de data para a hora equivalente em UTC.

Esse parâmetro foi introduzido no PowerShell 7.1.

Type:SwitchParameter
Position:Named
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-Date

Especifica uma data e hora. A hora é opcional e, se não for especificada, retornará 00:00:00. Insira a data e a hora em um formato padrão para a localidade selecionada no momento. Você pode alterar a localidade atual usando o Set-Culture cmdlet .

Por exemplo, em inglês dos EUA:

Get-Date -Date "6/25/2019 12:30:22" retorna terça-feira, 25 de junho de 2019 12:30:22

Type:DateTime
Aliases:LastWriteTime
Position:0
Default value:None
Required:False
Accept pipeline input:True
Accept wildcard characters:False

-Day

Especifica o dia do mês que é exibido. Insira um valor de 1 a 31.

Se o valor especificado for maior que o número de dias em um mês, o PowerShell adicionará o número de dias ao mês. Por exemplo, Get-Date -Month 4 -Day 31 exibe 1º de maio, não 31 de abril.

Type:Int32
Position:Named
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-DisplayHint

Determina quais elementos de data e hora são exibidos.

Os valores aceitos são os seguintes:

  • Data: exibe apenas a data
  • Hora: exibe apenas a hora
  • DateTime: exibe a data e a hora
Type:DisplayHintType
Accepted values:Date, Time, DateTime
Position:Named
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-Format

Exibe a data e hora no formato do Microsoft .NET Framework indicado pelo especificador de formato. O parâmetro Format gera um objeto String .

Para obter uma lista de especificadores de formato .NET disponíveis, consulte Cadeias de caracteres de formato de data e hora personalizados.

Quando o parâmetro Format é usado, Get-Date obtém apenas as propriedades do objeto DateTime necessárias para exibir a data. Como resultado, algumas das propriedades e métodos de objetos DateTime podem não estar disponíveis.

A partir do PowerShell 5.0, você pode usar os seguintes formatos adicionais como valores para o parâmetro Format .

  • FileDate. Uma representação amigável de arquivo ou caminho da data atual no horário local. O formato é yyyyMMdd (diferencia maiúsculas de minúsculas, usando um ano de 4 dígitos, um mês de 2 dígitos e um dia de 2 dígitos). Por exemplo: 20190627.

  • FileDateUniversal. Uma representação amigável de arquivo ou caminho da data atual em tempo universal (UTC). O formato é yyyyMMddZ (diferencia maiúsculas de minúsculas, usando um ano de 4 dígitos, um mês de 2 dígitos, um dia de 2 dígitos e a letra Z como indicador UTC). Por exemplo: 20190627Z.

  • FileDateTime. Uma representação amigável de arquivo ou caminho da data e hora atuais no horário local, em formato de 24 horas. O formato é yyyyMMddTHHmmssffff (diferencia maiúsculas de minúsculas, usando um ano de 4 dígitos, um mês de 2 dígitos, um dia de 2 dígitos, a letra T como separador de tempo, hora de 2 dígitos, minuto de 2 dígitos, segundo de 2 dígitos e milissegundo de 4 dígitos). Por exemplo: 20190627T0840107271.

  • FileDateTimeUniversal. Uma representação amigável de arquivo ou caminho da data e hora atuais em utc (tempo universal), no formato de 24 horas. O formato é yyyyMMddTHHmmssffffZ (diferencia maiúsculas de minúsculas, usando um mês de 4 dígitos, um mês de 2 dígitos, um dia de 2 dígitos, a letra T como separador de tempo, hora de 2 dígitos, minuto de 2 dígitos, segundo de 2 dígitos, milissegundo de 4 dígitos e a letra Z como indicador UTC). Por exemplo: 20190627T1540500718Z.

Type:String
Position:Named
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-Hour

Especifica a hora que é exibida. Insira um valor de 0 a 23.

Type:Int32
Position:Named
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-Millisecond

Especifica os milissegundos na data. Insira um valor de 0 a 999.

Esse parâmetro foi introduzido no PowerShell 3.0.

Type:Int32
Position:Named
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-Minute

Especifica o minuto que é exibido. Insira um valor de 0 a 59.

Type:Int32
Position:Named
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-Month

Especifica o mês que é exibido. Insira um valor de 1 a 12.

Type:Int32
Position:Named
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-Second

Especifica o segundo que é exibido. Insira um valor de 0 a 59.

Type:Int32
Position:Named
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-UFormat

Exibe a data e hora no formato UNIX. O parâmetro UFormat gera um objeto de cadeia de caracteres.

Os especificadores UFormat são precedidos por um sinal de porcentagem (%), por exemplo, %m, %de %Y. A seção Anotações contém uma tabela de especificadores UFormat válidos.

Quando o parâmetro UFormat é usado, Get-Date obtém apenas as propriedades do objeto DateTime necessárias para exibir a data. Como resultado, algumas das propriedades e métodos de objetos DateTime podem não estar disponíveis.

Type:String
Position:Named
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-UnixTimeSeconds

Data e hora representadas em segundos desde 1º de janeiro de 1970, 0:00:00.

Esse parâmetro foi introduzido no PowerShell 7.1.

Type:Int64
Aliases:UnixTime
Position:Named
Default value:None
Required:True
Accept pipeline input:False
Accept wildcard characters:False

-Year

Especifica o ano que é exibido. Insira um valor de 1 a 9999.

Type:Int32
Position:Named
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:False

Entradas

DateTime

Você pode canalizar um objeto DateTime para este cmdlet.

Saídas

DateTime

Por padrão, esse cmdlet retorna um objeto DateTime .

Quando um objeto DateTime é enviado pelo pipeline para um cmdlet como Add-Content que espera entrada de cadeia de caracteres, o PowerShell converte o objeto em um objeto String .

O ToString() converte um objeto DateTime em uma cadeia de caracteres usando a configuração de cultura atual. No entanto, a interpretação de expressão do PowerShell sempre usa a configuração de cultura invariável. Para ver como a cultura invariável é diferente, consulte Exemplo 11.

Para exibir as propriedades e os métodos de um objeto, envie o objeto pelo pipeline para Get-Member. Por exemplo, Get-Date | Get-Member.

String

Quando você usa os parâmetros Format ou UFormat , esse cmdlet retorna objetos String .

Observações

Os formatos padrão para a saída de objetos DateTime são formatos de data e hora longa para a localidade selecionada no momento.

Os especificadores UFormat válidos são exibidos na tabela a seguir:

Importante

Os especificadores UFormat são alterados ou adicionados em versões mais recentes do PowerShell. Por exemplo, %F foi adicionado no PowerShell 6.2, portanto, ele não está disponível no Windows PowerShell 5.1 ou mais antigo. Tenha isso em mente ao usar especificadores UFormat em scripts projetados para serem executados em várias versões do PowerShell.

Especificador de formato Significado Exemplo
%A Dia da semana - nome completo Monday
%a Dia da semana - nome abreviado Mon
%B Nome do mês – completo Janeiro
%b Nome do mês – abreviado Jan
%C Século 20 para 2019
%c Data e hora - abreviada Qui 27 jun 08:44:18 2019
%D Data no formato mm/dd/yy 06/27/19
%d Dia do mês - 2 dígitos 05
%e Dia do mês - precedido por um espaço se apenas um único dígito <espaço>5
%F Data no formato AAAA-mm-dd, igual a %Y-%m-%d (o formato de data ISO 8601) 2019-06-27
%G Ano de data da semana ISO (ano que contém quinta-feira da semana)
%g O mesmo que 'G' - 2 dígitos
%H Hora no formato de 24 horas 17
%h O mesmo que 'b'
%I Hora no formato de 12 horas 05
%j Dia do ano 1-366
%k O mesmo que 'H'
%l O mesmo que 'I' (maiúsculas e minúsculas I) 05
%M minutos 35
%m Número do mês 06
%n caractere newline
%p AM ou PM
%R Tempo no formato de 24 horas - sem segundos 17:45
%r Tempo no formato de 12 horas 09:15:36 AM
%S Segundos 05
%s Segundos decorridos desde 1º de janeiro de 1970 00:00:00 (UTC) 1150451174
%t Caractere de tabulação horizontal
%T Tempo no formato de 24 horas 17:45:52
%U O mesmo que 'W'
%u Dia numérico da semana (1 a 7) (alterado no PowerShell 7.2) Segunda-feira = 1, domingo = 7
%V Semana do ano 01-53
%w Dia numérico da semana (0-6) Domingo = 0, sábado = 6
%W Semana do ano 00-52
%X O mesmo que 'T'
%x Data no formato padrão para localidade 27/06/19 para Inglês-EUA
%Y Ano no formato de 4 dígitos 2019
%y Ano no formato de dois dígitos 19
%Z Deslocamento de fuso horário da Coordenada de Tempo Universal (UTC) -07

Observação

O comportamento de -UFormat %s foi alterado para corrigir problemas com o comportamento em Windows PowerShell.

  • O valor retornado é baseado na hora UTC.
  • O valor é um valor de número inteiro de segundos (sem parte fracionária).