Get-Date
Ottiene la data e l'ora correnti.
Sintassi
Get-Date
[[-Date] <datetime>]
[-Year <int>]
[-Month <int>]
[-Day <int>]
[-Hour <int>]
[-Minute <int>]
[-Second <int>]
[-Millisecond <int>]
[-DisplayHint <DisplayHintType>]
[-Format <string>]
[<CommonParameters>]
Get-Date
[[-Date] <datetime>]
[-Year <int>]
[-Month <int>]
[-Day <int>]
[-Hour <int>]
[-Minute <int>]
[-Second <int>]
[-Millisecond <int>]
[-DisplayHint <DisplayHintType>]
[-UFormat <string>]
[<CommonParameters>]
Descrizione
Il Get-Date
cmdlet ottiene un oggetto DateTime che rappresenta la data corrente o una data specificata. Get-Date
può formattare la data e l'ora in diversi formati .NET e UNIX. È possibile usare Get-Date
per generare una stringa di caratteri data o ora e quindi inviare la stringa ad altri cmdlet o programmi.
Get-Date
usa le impostazioni cultura del computer per determinare la modalità di formattazione dell'output. Per visualizzare le impostazioni del computer, usare (Get-Culture).DateTimeFormat
.
Esempio
Esempio 1: ottenere la data e l'ora correnti
In questo esempio viene Get-Date
visualizzata la data e l'ora di sistema correnti. L'output si trova nei formati long-date e long-time.
Get-Date
Tuesday, June 25, 2019 14:53:32
Esempio 2: Ottenere elementi della data e dell'ora correnti
In questo esempio viene illustrato come usare Get-Date
per ottenere l'elemento data o ora. Il parametro usa gli argomenti Date, Time o DateTime.
Get-Date -DisplayHint Date
Tuesday, June 25, 2019
Get-Date
usa il parametro DisplayHint con l'argomento Date per ottenere solo la data.
Esempio 3: ottenere la data e l'ora con un identificatore di formato .NET
In questo esempio viene usato un identificatore di formato .NET per personalizzare il formato dell'output. L'output è un oggetto String .
Get-Date -Format "dddd MM/dd/yyyy HH:mm K"
Tuesday 06/25/2019 16:17 -07:00
Get-Date
usa il parametro Format per specificare diversi identificatori di formato.
Gli identificatori di formato .NET usati in questo esempio sono definiti come segue:
Identificatore | Definizione |
---|---|
dddd |
Giorno della settimana - nome completo |
MM |
Numero del mese |
dd |
Giorno del mese - 2 cifre |
yyyy |
Anno in formato a 4 cifre |
HH:mm |
Tempo in formato 24 ore -no secondi |
K |
Offset del fuso orario da Coordinate ora universale (UTC) |
Per altre informazioni sugli identificatori di formato .NET, vedere Stringhe di formato data e ora personalizzate.
Esempio 4: ottenere la data e l'ora con un identificatore UFormat
In questo esempio vengono usati diversi identificatori di formato UFormat per personalizzare il formato dell'output. L'output è un oggetto String .
Get-Date -UFormat "%A %m/%d/%Y %R %Z"
Tuesday 06/25/2019 16:19 -07
Get-Date
usa il parametro UFormat per specificare diversi identificatori di formato.
Gli identificatori di formato UFormat usati in questo esempio sono definiti come segue:
Identificatore | Definizione |
---|---|
%A |
Giorno della settimana - nome completo |
%m |
Numero del mese |
%d |
Giorno del mese - 2 cifre |
%Y |
Anno in formato a 4 cifre |
%R |
Tempo in formato 24 ore -no secondi |
%Z |
Offset del fuso orario da Coordinate ora universale (UTC) |
Per un elenco di identificatori di formato UFormat validi, vedere la sezione Note .
Esempio 5: Ottenere un giorno dell'anno
In questo esempio viene usata una proprietà per ottenere il giorno numerico dell'anno.
Il calendario gregoriano ha 365 giorni, ad eccezione di anni salti che hanno 366 giorni. Ad esempio, il 31 dicembre 2020 è il giorno 366.
(Get-Date -Year 2020 -Month 12 -Day 31).DayOfYear
366
Get-Date
usa tre parametri per specificare la data: anno, mese e giorno. Il comando viene eseguito con parentesi in modo che il risultato venga valutato dalla proprietà DayofYear .
Esempio 6: verificare se una data viene modificata per l'ora legale
In questo esempio viene usato un metodo booleano per verificare se una data viene modificata in base all'ora legale.
$DST = Get-Date
$DST.IsDaylightSavingTime()
True
Una variabile archivia $DST
il risultato di Get-Date
. $DST
usa il metodo IsDaylightSavingTime per verificare se la data viene modificata per l'ora legale.
Esempio 7: Convertire l'ora corrente in ora UTC
In questo esempio l'ora corrente viene convertita in ora UTC. L'offset UTC per le impostazioni locali del sistema viene usato per convertire l'ora. Una tabella nella sezione Note elenca gli identificatori di formato UFormat validi.
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 il parametro UFormat con gli identificatori di formato per visualizzare la data e l'ora di sistema correnti. L'identificatore di formato %Z rappresenta l'offset UTC di -07.
La $Time
variabile archivia la data e l'ora correnti del sistema. $Time
usa il metodo ToUniversalTime() per convertire l'ora in base all'offset UTC del computer.
Esempio 8: Create un timestamp
In questo esempio un identificatore di formato crea un oggetto String timestamp per un nome di directory. Il timestamp include la data, l'ora e l'offset 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
La $timestamp
variabile archivia i risultati di un Get-Date
comando. Get-Date
usa il parametro Format con l'identificatore di formato minuscolo o
per creare un oggetto String timestamp. L'oggetto viene inviato alla pipeline a ForEach-Object
. ScriptBlock contiene la variabile che rappresenta l'oggetto $_
pipeline corrente. La stringa timestamp è delimitata da punti sostituiti da punti.
New-Item
usa il parametro Path per specificare il percorso per una nuova directory. Il percorso include la $timestamp
variabile come nome della directory. Il parametro Type specifica che viene creata una directory.
Parametri
-Date
Specifica una data e un'ora. L'ora è facoltativa e, se non specificata, restituisce 00:00:00.
Immettere la data e l'ora in un formato standard per le impostazioni locali del sistema.
Ad esempio, in inglese statunitense:
Get-Date -Date "6/25/2019 12:30:22"
restituisce martedì 25 giugno 2019 12:30:22
Type: | DateTime |
Aliases: | LastWriteTime |
Position: | 0 |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-Day
Specifica il giorno del mese visualizzato. Immettere un valore compreso tra 1 e 31.
Se il valore specificato è maggiore del numero di giorni in un mese, PowerShell aggiunge il numero di giorni al mese. Ad esempio, Get-Date -Month 2 -Day 31
visualizza il 3 marzo, non il 31 febbraio.
Type: | Int |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-DisplayHint
Determina quali elementi della data e dell'ora visualizzare.
I valori accettati sono i seguenti:
- Data: visualizza solo la data
- Ora: visualizza solo l'ora
- DateTime: visualizza la data e l'ora
Type: | DisplayHintType |
Accepted values: | Date, Time, DateTime |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Format
Visualizza la data e l'ora nel formato di Microsoft .NET Framework indicato dall'identificatore di formato. Il parametro Format restituisce un oggetto String .
Per un elenco degli identificatori di formato .NET disponibili, vedere Stringhe di formato data e ora personalizzate.
Quando viene usato il parametro Format , Get-Date
ottiene solo le proprietà dell'oggetto DateTime necessarie per visualizzare la data. Di conseguenza, alcune proprietà e alcuni metodi degli oggetti DateTime potrebbero non essere disponibili.
A partire da PowerShell 5.0, è possibile usare i formati aggiuntivi seguenti come valori per il parametro Format .
FileDate. Rappresentazione descrittiva del file o del percorso della data corrente nell'ora locale. Il formato è
yyyyMMdd
(distinzione tra maiuscole e minuscole, usando un anno a 4 cifre, un mese a 2 cifre e un giorno a 2 cifre). Ad esempio: 20190627.FileDateUniversal. Rappresentazione descrittiva del file o del percorso della data corrente nell'ora UTC (Universal Time). Il formato è
yyyyMMddZ
(distinzione tra maiuscole e minuscole, usando un anno a 4 cifre, un mese a 2 cifre, un giorno a 2 cifre e la letteraZ
come indicatore UTC). Ad esempio: 20190627Z.FileDateTime. Rappresentazione descrittiva del file o del percorso della data e dell'ora corrente nell'ora locale, in formato di 24 ore. Il formato è
yyyyMMddTHHmmssffff
(distinzione tra maiuscole e minuscole, usando un anno a 4 cifre, un mese a 2 cifre, un giorno a 2 cifre, la letteraT
come separatore temporale, ora a 2 cifre, minuto a 2 cifre, secondo di 2 cifre e millisecondi a 4 cifre). Ad esempio: 20190627T0840107271.FileDateTimeUniversal. Rappresentazione descrittiva del file o del percorso della data e dell'ora corrente in formato UTC (Universal Time), in formato 24 ore. Il formato è
yyyyMMddTHHmmssffffZ
(distinzione tra maiuscole e minuscole, usando un anno a 4 cifre, un mese a 2 cifre, un giorno a 2 cifre, la letteraT
come separatore temporale, un'ora a 2 cifre, un minuto a 2 cifre, un secondo secondo a 4 cifre e la letteraZ
come indicatore UTC). Ad esempio: 20190627T1540500718Z.
Type: | String |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Hour
Specifica l'ora visualizzata. Immettere un valore compreso tra 0 e 23.
Type: | Int |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Millisecond
Specifica i millisecondi nella data. Immettere un valore compreso tra 0 e 999.
Questo parametro è stato introdotto in PowerShell 3.0.
Type: | Int |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Minute
Specifica il minuto visualizzato. Immettere un valore compreso tra 0 e 59.
Type: | Int |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Month
Specifica il mese visualizzato. Immettere un valore compreso tra 1 e 12.
Type: | Int |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Second
Specifica i secondi visualizzati. Immettere un valore compreso tra 0 e 59.
Type: | Int |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-UFormat
Visualizza la data e l'ora nel formato UNIX. Il parametro UFormat restituisce un oggetto stringa.
Gli identificatori UFormat sono preceduti da un segno percentuale (%
), ad esempio , %m
, %d
e %Y
. La sezione Note contiene una tabella di identificatori UFormat validi.
Quando viene usato il parametro UFormat , Get-Date
ottiene solo le proprietà dell'oggetto DateTime necessarie per visualizzare la data. Di conseguenza, alcune proprietà e alcuni metodi degli oggetti DateTime potrebbero non essere disponibili.
Type: | String |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Year
Specifica l'anno visualizzato. Immettere un valore compreso tra 1 e 9999.
Type: | Int |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
Input
Pipeline input
Get-Date
accetta l'input della pipeline. Ad esempio: Get-ChildItem | Get-Date
.
Output
System.DateTime or System.String
Get-Date
restituisce un oggetto DateTime tranne quando vengono usati i parametri Format e UFormat . I parametri Format o UFormat restituiscono oggetti String .
Quando un oggetto DateTime viene inviato alla pipeline a un cmdlet, ad Add-Content
esempio che prevede l'input stringa, PowerShell converte l'oggetto in un oggetto String .
Il metodo (Get-Date).ToString()
converte un oggetto DateTime un oggetto String .
Per visualizzare le proprietà e i metodi di un oggetto, inviare l'oggetto alla pipeline a Get-Member
.
Ad esempio: Get-Date | Get-Member
.
Note
Gli oggetti DateTime sono in formati di lunga data e di lunga durata per le impostazioni locali del sistema.
Gli identificatori UFormat validi vengono visualizzati nella tabella seguente:
Identificatore di formato | Significato | Esempio |
---|---|---|
%A |
Giorno della settimana - nome completo | Monday |
%a |
Giorno della settimana - nome abbreviato | Mon |
%B |
Nome mese - completo | January |
%b |
Nome mese - abbreviato | Gen |
%C |
Secolo | 20 per il 2019 |
%c |
Data e ora - abbreviato | Thu Jun 27 08:44:18 2019 |
%D |
Data in mm/dd/y formato | 06/27/19 |
%d |
Giorno del mese - 2 cifre | 05 |
%e |
Giorno del mese - cifra preceduta da uno spazio | <spazio>5 |
%F |
Data in formato YAAA-mm-dd, uguale a %Y-%m-%d (formato di data ISO 8601) | 2019-06-27 |
%G |
Uguale a 'Y' | |
%g |
Uguale a 'y' | |
%H |
Ora in formato 24 ore | 17 |
%h |
Uguale a 'b' | |
%I |
Ora in formato 12 ore | 05 |
%j |
Giorno dell'anno | 1-366 |
%k |
Uguale a 'H' | |
%l |
Uguale a 'I' (maiuscolo I) | 05 |
%M |
Minuti | 35 |
%m |
Numero del mese | 06 |
%n |
carattere newline | |
%p |
AM o PM | |
%R |
Tempo in formato 24 ore -no secondi | 17:45 |
%r |
Ora in formato 12 ore | 09:15:36 |
%S |
Secondi | 05 |
%s |
Secondi trascorsi dal 1 gennaio 1970 00:00:00 | 1150451174.95705 |
%t |
Carattere di scheda orizzontale | |
%T |
Tempo in formato 24 ore | 17:45:52 |
%U |
Uguale a 'W' | |
%u |
Giorno della settimana - numero | Lunedì = 1 |
%V |
Settimana dell'anno | 01-53 |
%w |
Uguale a 'u' | |
%W |
Settimana dell'anno | 00-52 |
%X |
Uguale a 'T' | |
%x |
Data in formato standard per le impostazioni locali | 06/27/19 per inglese-US |
%Y |
Anno in formato a 4 cifre | 2019 |
%y |
Anno in formato a 2 cifre | 19 |
%Z |
Offset del fuso orario da Coordinate ora universale (UTC) | -07 |