Get-Random
Ottiene un numero casuale o seleziona oggetti in modo casuale da una raccolta.
Sintassi
Get-Random
[-SetSeed <Int32>]
[[-Maximum] <Object>]
[-Minimum <Object>]
[-Count <Int32>]
[<CommonParameters>]
Get-Random
[-SetSeed <Int32>]
[-InputObject] <Object[]>
[-Count <Int32>]
[<CommonParameters>]
Get-Random
[-SetSeed <Int32>]
[-InputObject] <Object[]>
[-Shuffle]
[<CommonParameters>]
Descrizione
Il Get-Random
cmdlet ottiene un numero selezionato in modo casuale. Se si invia una raccolta di oggetti a Get-Random
, ottiene uno o più oggetti selezionati in modo casuale dalla raccolta.
Senza parametri o input, un Get-Random
comando restituisce un intero senza segno a 32 bit selezionato in modo casuale tra 0 (zero) e [int32]::MaxValue
.
È possibile utilizzare i parametri di Get-Random
per specificare i valori minimo e massimo, il numero di oggetti restituiti da una raccolta o un numero di inizializzazione.
Attenzione
Get-Random
non garantisce la sicurezza crittografica casuale. Il valore di inizializzazione viene usato per il comando corrente e per tutti i comandi successivi Get-Random
nella sessione corrente fino a quando non si usa di nuovo SetSeed o si chiude la sessione. Non è possibile reimpostare il valore di inizializzazione sul valore predefinito.
L'impostazione intenzionale del valore di inizializzazione comporta un comportamento ripetibile non casuale. Deve essere usato solo quando si tenta di riprodurre il comportamento, ad esempio durante il debug o l'analisi di uno script che include Get-Random
comandi. Tenere presente che il valore di inizializzazione può essere impostato da altro codice nella stessa sessione, ad esempio un modulo importato.
PowerShell 7.4 include Get-SecureRandom
, che garantisce la sicurezza crittografica casuale.
Esempio
Esempio 1: Ottenere un numero intero casuale
Questo comando ottiene un numero intero casuale compreso tra 0 (zero) e Int32.MaxValue.
Get-Random
3951433
Esempio 2: Ottenere un numero intero casuale compreso tra 0 e 99
Get-Random -Maximum 100
47
Esempio 3: Ottenere un numero intero casuale compreso tra -100 e 99
Get-Random -Minimum -100 -Maximum 100
56
Esempio 4: Ottenere un numero a virgola mobile casuale
Questo comando ottiene un numero a virgola mobile casuale maggiore o uguale a 10,7 e minore di 20,93.
Get-Random -Minimum 10.7 -Maximum 20.93
18.08467273887
Esempio 5: Ottenere un numero intero casuale da una matrice
Questo comando ottiene un numero selezionato in modo casuale dalla matrice specificata.
1, 2, 3, 5, 8, 13 | Get-Random
8
Esempio 6: Ottenere diversi numeri interi casuali da una matrice
Questo comando ottiene tre numeri selezionati in modo casuale in ordine casuale da una matrice.
1, 2, 3, 5, 8, 13 | Get-Random -Count 3
3
1
13
Esempio 7: Casualizzare un'intera raccolta
A partire da PowerShell 7.1, è possibile usare il parametro Shuffle per restituire l'intera raccolta in un ordine casuale.
1, 2, 3, 5, 8, 13 | Get-Random -Shuffle
2
3
5
1
8
13
Esempio 8: Ottenere un valore casuale non numerico
Questo comando restituisce un valore casuale da una raccolta non numerica.
"red", "yellow", "blue" | Get-Random
yellow
Esempio 9: Usare il parametro SetSeed
Questo esempio mostra l'effetto dell'uso del parametro SetSeed.
Poiché SetSeed produce un comportamento non casuale, viene in genere usato solo per riprodurre i risultati, ad esempio durante il debug o l'analisi di uno script.
# Commands with the default seed are pseudorandom
Get-Random -Maximum 100 -SetSeed 23
Get-Random -Maximum 100
Get-Random -Maximum 100
Get-Random -Maximum 100
32
25
93
95
# Commands with the same seed aren't random
Get-Random -Maximum 100 -SetSeed 23
Get-Random -Maximum 100 -SetSeed 23
Get-Random -Maximum 100 -SetSeed 23
32
32
32
# SetSeed results in a repeatable series
Get-Random -Maximum 100 -SetSeed 23
Get-Random -Maximum 100
Get-Random -Maximum 100
Get-Random -Maximum 100
32
25
93
95
Esempio 10: Ottenere file casuali
Questi comandi ottengono un campione selezionato casualmente di 50 file dall'unità C:
del computer locale.
$Files = Get-ChildItem -Path C:\* -Recurse
$Sample = $Files | Get-Random -Count 50
Esempio 11: Roll fair dadi
Questo esempio esegue il rollup di un die fair die 1200 volte e conta i risultati. Il primo comando ForEach-Object
ripete la chiamata a Get-Random
dal pipe in numeri (1-6). I risultati vengono raggruppati in base al valore con Group-Object
e formattati come tabella con Select-Object
.
1..1200 | ForEach-Object {
1..6 | Get-Random
} | Group-Object | Select-Object Name,Count
Name Count
---- -----
1 206
2 199
3 196
4 226
5 185
6 188
Esempio 12: Usare il parametro Count
È ora possibile usare il parametro Count senza eseguire piping di oggetti in Get-Random
.
L'esempio seguente ottiene tre numeri casuali inferiori a 10.
Get-Random -Count 3 -Maximum 10
9
0
8
Esempio 13: Usare il parametro InputObject con una stringa vuota o $null
In questo esempio, il parametro InputObject specifica una matrice che contiene una stringa vuota (''
) e $null
.
Get-Random -InputObject @('a','',$null)
Get-Random
a
restituisce , stringa vuota o $null
. Lo sting vuoto viene visualizzato come riga vuota e $null
torna a un prompt di PowerShell.
Parametri
-Count
Specifica il numero di oggetti casuali da restituire. Il valore predefinito è 1.
Se usato con InputObject
contenente una raccolta:
- Ogni elemento selezionato in modo casuale viene restituito una sola volta.
- Se il valore di Count supera il numero di oggetti nell'insieme, tutti gli oggetti nella raccolta vengono restituiti in ordine casuale.
Type: | Int32 |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-InputObject
Specifica una raccolta di oggetti. Get-Random
ottiene oggetti selezionati in modo casuale in ordine casuale dalla raccolta fino al numero specificato da Count. Immettere gli oggetti, una variabile che contiene gli oggetti oppure un comando o un'espressione che ottiene gli oggetti. È anche possibile inviare tramite pipe una raccolta di oggetti a Get-Random
.
A partire da PowerShell 7, il parametro InputObject accetta matrici che possono contenere una stringa vuota o $null
. La matrice può essere inviata alla pipeline o come valore del parametro InputObject .
Type: | Object[] |
Position: | 0 |
Default value: | None |
Required: | True |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-Maximum
Specifica un valore massimo per il numero casuale. Get-Random
restituisce un valore minore del valore massimo (diverso da). Immettere un numero intero, un numero a virgola mobile e precisione doppia o un oggetto che può essere convertito in un numero intero o double, ad esempio una stringa numerica ("100").
Il valore di Maximum deve essere superiore (non uguale) al valore di Minimum. Se il valore di Maximum o Minimum è un numero a virgola mobile, Get-Random
restituisce un numero a virgola mobile selezionato in modo casuale.
In un computer a 64 bit, se il valore di Minimum è un numero intero a 32 bit, il valore predefinito di Maximum è Int32.MaxValue.
Se il valore di Minimum è un valore double (un numero a virgola mobile), il valore predefinito di Maximum è Double.MaxValue. In caso contrario, il valore predefinito è Int32.MaxValue.
Type: | Object |
Position: | 0 |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Minimum
Specifica un valore minimo per il numero casuale. Immettere un numero intero, un numero a virgola mobile e precisione doppia o un oggetto che può essere convertito in un numero intero o double, ad esempio una stringa numerica ("100"). Il valore predefinito è 0 (zero).
Il valore di Minimum deve essere inferiore (non uguale) al valore di Maximum. Se il valore di Maximum o Minimum è un numero a virgola mobile, Get-Random
restituisce un numero a virgola mobile selezionato in modo casuale.
Type: | Object |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-SetSeed
Specifica un valore di inizializzazione per il generatore di numeri casuali. Quando si usa SetSeed, il cmdlet genera numeri pseudorandomi, che non sono crittografati.
Attenzione
L'impostazione del valore di inizializzazione comporta un comportamento non casuale. Deve essere usato solo quando si tenta di riprodurre il comportamento, ad esempio durante il debug o l'analisi di uno script che include Get-Random
comandi.
Questo valore di inizializzazione viene usato per il comando corrente e per tutti i comandi successivi Get-Random
nella sessione corrente fino a quando non si usa di nuovo SetSeed o si chiude la sessione. Non è possibile reimpostare il valore di inizializzazione sul valore predefinito.
Type: | Nullable<T>[Int32] |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Shuffle
Restituisce l'intera raccolta in un ordine casuale.
Type: | SwitchParameter |
Position: | Named |
Default value: | None |
Required: | True |
Accept pipeline input: | False |
Accept wildcard characters: | False |
Input
È possibile inviare tramite pipe qualsiasi oggetto a questo cmdlet. Seleziona i valori in modo casuale dagli oggetti inviati tramite pipe.
Output
Questo cmdlet restituisce un numero intero o a virgola mobile o un oggetto selezionato in modo casuale da una raccolta inviata.
Note
Get-Random
non restituisce sempre lo stesso tipo di dati del valore di input. Nella tabella seguente viene illustrato il tipo di output per ognuno dei tipi di input numerici.
Tipo di input | Tipo di output |
---|---|
SByte | Double |
Byte | Double |
Int16 | Double |
UInt16 | Double |
Int32 | Int32 |
UInt32 | Double |
Int64 | Int64 |
UInt64 | Double |
Double | Double |
Single | Double |
A partire da Windows PowerShell 3.0, Get-Random
supporta interi a 64 bit. In Windows PowerShell 2.0 viene eseguito il cast di tutti i valori a System.Int32.
A partire da PowerShell 7, il parametro InputObject nel set di parametri RandomListItemParameterSet accetta matrici che contengono una stringa vuota o $null
. Nelle versioni precedenti di PowerShell, solo il parametro Maximum nel set di parametri RandomNumberParameterSet ha accettato una stringa vuota o $null
.