Condividi tramite


about_Arrays

Descrizione breve

Vengono descritte le matrici, ovvero strutture di dati progettate per archiviare raccolte di elementi.

Descrizione lunga

Una matrice è una struttura di dati progettata per archiviare una raccolta di elementi. Gli elementi possono essere dello stesso tipo o tipi diversi.

A partire da Windows PowerShell 3.0, una raccolta di zero o un oggetto ha alcune proprietà delle matrici.

Creazione e inizializzazione di una matrice

Per creare e inizializzare una matrice, assegnare più valori a una variabile. I valori archiviati nella matrice sono delimitati da una virgola e separati dal nome della variabile dall'operatore di assegnazione (=).

Ad esempio, per creare una matrice denominata $A che contiene i sette valori numerici (integer) di 22, 5, 10, 8, 12, 9 e 80, digitare:

$A = 22,5,10,8,12,9,80

La virgola può essere usata anche per inizializzare una singola matrice di elementi posizionando la virgola prima del singolo elemento.

Ad esempio, per creare una singola matrice di elementi denominata $B contenente il singolo valore 7, digitare:

$B = ,7

È anche possibile creare e inizializzare una matrice usando l'operatore range (..). Nell'esempio seguente viene creata una matrice contenente i valori da 5 a 8.

$C = 5..8

Di conseguenza, $C contiene quattro valori: 5, 6, 7 e 8.

Quando non viene specificato alcun tipo di dati, PowerShell crea ogni matrice come matrice di oggetti (System.Object[]). Per determinare il tipo di dati di una matrice, usare il GetType() metodo . Ad esempio:

$A.GetType()

Per creare una matrice fortemente tipizzata, ovvero una matrice che può contenere solo valori di un particolare tipo, eseguire il cast della variabile come tipo di matrice, ad esempio string[], long[]o int32[]. Per eseguire il cast di una matrice, precedere il nome della variabile con un tipo di matrice racchiuso tra parentesi quadre. Ad esempio:

[int32[]]$ia = 1500, 2230, 3350, 4000

Di conseguenza, la $ia matrice può contenere solo numeri interi.

È possibile creare matrici di cui viene eseguito il cast in qualsiasi tipo supportato in .NET. Ad esempio, gli oggetti recuperati Get-Process per rappresentare i processi sono del tipo System.Diagnostics.Process . Per creare una matrice fortemente tipizzata di oggetti processo, immettere il comando seguente:

[Diagnostics.Process[]]$zz = Get-Process

Operatore di sottoespressione della matrice

L'operatore di sottoespressione della matrice crea una matrice dalle istruzioni al suo interno. Indipendentemente dall'istruzione all'interno dell'operatore, l'operatore lo inserisce in una matrice. Anche se è presente zero o un oggetto.

La sintassi dell'operatore di matrice è la seguente:

@( ... )

È possibile usare l'operatore di matrice per creare una matrice di zero o un oggetto. Ad esempio:

$a = @("Hello World")
$a.Count
1
$b = @()
$b.Count
0

L'operatore di matrice è utile negli script quando si ottengono oggetti, ma non si sa quanti si aspettano. Ad esempio:

$p = @(Get-Process Notepad)

Per altre informazioni sull'operatore di sottoespressione della matrice, vedere about_Operators.

Accesso e uso di elementi di matrice

Lettura di una matrice

È possibile fare riferimento a una matrice usando il nome della variabile. Per visualizzare tutti gli elementi nella matrice, richiamare il nome della matrice. Ad esempio, $a è una matrice di numeri da 0 a 9:

$a
0
1
2
3
4
5
6
7
8
9

È possibile fare riferimento agli elementi di una matrice usando un indice. Racchiudere il numero di indice tra parentesi quadre. I valori di indice iniziano da 0. Ad esempio, per visualizzare l'elemento first nella $a matrice, digitare:

$a[0]
0

Per visualizzare il terzo elemento nella $a matrice, digitare:

$a[2]
2

È possibile recuperare parte della matrice usando un operatore di intervallo per l'indice. Ad esempio, per recuperare il secondo al quinto elemento della matrice, digitare:

$a[1..4]
1
2
3
4

Numeri count negativi dalla fine della matrice. Ad esempio, -1 fa riferimento all'elemento last della matrice. Per visualizzare i last tre elementi della matrice, in ordine crescente di indice, digitare:

$a = 0 .. 9
$a[-3..-1]
7
8
9

Se si digitano indici negativi in ordine decrescente, l'output cambia.

$a = 0 .. 9
$a[-1..-3]
9
8
7

Tuttavia, prestare attenzione quando si usa questa notazione. I cicli di notazione dal limite finale all'inizio della matrice.

$a = 0 .. 9
$a[2..-2]
2
1
0
9
8

Inoltre, un errore comune consiste nel presupporre $a[0..-2] che faccia riferimento a tutti gli elementi della matrice, ad eccezione di last quello. Fa riferimento agli firstelementi , laste second-to-nellalast matrice.

È possibile usare l'operatore più (+) per combinare un intervallo con un elenco di elementi in una matrice. Ad esempio, per visualizzare gli elementi in corrispondenza delle posizioni di indice da 0, 2 e 4 a 6, digitare:

$a = 0 .. 9
$a[0,2+4..6]
0
2
4
5
6

Inoltre, per elencare più intervalli e singoli elementi è possibile usare l'operatore plus. Ad esempio, per elencare gli elementi da zero a due, da quattro a sei e l'elemento all'ottavo tipo posizionale:

$a = 0..9
$a[+0..2+4..6+8]
0
1
2
4
5
6
8

Iterazioni sugli elementi della matrice

È anche possibile usare costrutti di ciclo, ad esempio foreach, fore , per while fare riferimento agli elementi in una matrice. Ad esempio, per usare un foreach ciclo per visualizzare gli elementi nella $a matrice, digitare:

$a = 0..9
foreach ($element in $a) {
  $element
}
0
1
2
3
4
5
6
7
8
9

Il foreach ciclo scorre la matrice e restituisce ogni valore nella matrice until che raggiunge la fine della matrice.

Il for ciclo è utile quando si incrementano i contatori durante l'analisi degli elementi in una matrice. Ad esempio, per usare un for ciclo per restituire ogni altro valore in una matrice, digitare:

$a = 0..9
for ($i = 0; $i -le ($a.length - 1); $i += 2) {
  $a[$i]
}
0
2
4
6
8

È possibile usare un while ciclo per visualizzare gli elementi in una matrice until che una condizione definita non è più true. Ad esempio, per visualizzare gli elementi nella $a matrice mentre l'indice della matrice è minore di 4, digitare:

$a = 0..9
$i=0
while($i -lt 4) {
  $a[$i]
  $i++
}
0
1
2
3

Proprietà delle matrici

Count o Length o LongLength

Per determinare il numero di elementi in una matrice, usare la proprietà o il Length relativo Count alias. Longlength è utile se la matrice contiene più di 2.147.483.647 elementi.

$a = 0..9
$a.Count
$a.Length
10
10

Rank

Restituisce il numero di dimensioni nella matrice. La maggior parte delle matrici in PowerShell ha una sola dimensione. Anche quando si ritiene di creare una matrice multidimensionale come nell'esempio seguente:

$a = @(
  @(0,1),
  @("b", "c"),
  @(Get-Process)
)

"`$a rank: $($a.Rank)"
"`$a length: $($a.Length)"
"`$a[2] length: $($a[2].Length)"
"Process `$a[2][1]: $($a[2][1].ProcessName)"

In questo esempio si crea una matrice unidimensionale che contiene altre matrici. Questo è noto anche come matrice frastagliata. La Rank proprietà ha dimostrato che questo è unidimensionale. Per accedere agli elementi in una matrice irregolare, gli indici devono essere racchiusi tra parentesi quadre separate ([]).

$a rank: 1
$a length: 3
$a[2] length: 348
Process $a[2][1]: AcroRd32

Le matrici multidimensionali vengono archiviate in ordine principale di riga. Nell'esempio seguente viene illustrato come creare una matrice realmente multidimensionale.

[string[,]]$rank2 = [string[,]]::New(3,2)
$rank2.rank
$rank2.Length
$rank2[0,0] = 'a'
$rank2[0,1] = 'b'
$rank2[1,0] = 'c'
$rank2[1,1] = 'd'
$rank2[2,0] = 'e'
$rank2[2,1] = 'f'
$rank2[1,1]
2
6
d

Per accedere agli elementi in una matrice multidimensionale, separare gli indici usando una virgola (,) all'interno di un singolo set di parentesi quadre ([]).

Alcune operazioni su una matrice multidimensionale, ad esempio la replica e la concatenazione, richiedono che tale matrice venga appiattita. L'appiattimento trasforma la matrice in una matrice 1-dimensionale di tipo non vincolato. La matrice risultante accetta tutti gli elementi nell'ordine principale della riga. Si consideri l'esempio seguente:

$a = "red",$true
$b = (New-Object 'int[,]' 2,2)
$b[0,0] = 10
$b[0,1] = 20
$b[1,0] = 30
$b[1,1] = 40
$c = $a + $b
$a.GetType().Name
$b.GetType().Name
$c.GetType().Name
$c

L'output mostra che $c è una matrice 1-dimensionale contenente gli elementi da $a e $b in ordine principale di riga.

Object[]
Int32[,]
Object[]
red
True
10
20
30
40

Metodi di matrici

Clear

Imposta tutti i valori degli elementi sul default valore del tipo di elemento della matrice. Il Clear() metodo non reimposta le dimensioni della matrice.

Nell'esempio $a seguente è una matrice di oggetti .

$a = 1, 2, 3
$a.Clear()
$a | % { $null -eq $_ }
True
True
True

In questo esempio viene $intA digitato in modo esplicito per contenere numeri interi.

[int[]] $intA = 1, 2, 3
$intA.Clear()
$intA
0
0
0

ForEach()

Consente di scorrere tutti gli elementi nella matrice ed eseguire un'operazione specifica per ogni elemento della matrice.

Il ForEach() metodo dispone di diversi overload che eseguono operazioni diverse.

ForEach(scriptblock expression)
ForEach(scriptblock expression, object[] arguments)
ForEach(type convertToType)
ForEach(string propertyName)
ForEach(string propertyName, object[] newValue)
ForEach(string methodName)
ForEach(string methodName, object[] arguments)

ForEach(espressione scriptblock)

ForEach(espressione scriptblock, argomenti object[] )

Questo metodo è stato aggiunto in PowerShell v4.

Nota

La sintassi richiede l'utilizzo di un blocco di script. Le parentesi sono facoltative se lo scriptblock è l'unico parametro. Inoltre, non deve esistere uno spazio tra il metodo e la parentesi graffa di apertura.

Nell'esempio seguente viene illustrato come usare il ForEach() metodo . In questo caso, la finalità consiste nel generare il valore quadrato degli elementi nella matrice.

$a = @(0 .. 3)
$a.ForEach({ $_ * $_})
0
1
4
9

Proprio come il parametro ArgumentList di ForEach-Object, il arguments parametro consente il passaggio di una matrice di argomenti a un blocco di script configurato per accettarli.

Per altre informazioni sul comportamento di ArgumentList, vedere about_Splatting.

ForEach(type convertToType)

Il metodo può essere utilizzato per eseguire il cast degli elementi in un tipo diverso. Nell'esempio ForEach() seguente viene illustrato come convertire un elenco di date stringa in [DateTime] un tipo.

("1/1/2017", "2/1/2017", "3/1/2017").ForEach([datetime])

Sunday, January 1, 2017 12:00:00 AM
Wednesday, February 1, 2017 12:00:00 AM
Wednesday, March 1, 2017 12:00:00 AM

ForEach(string propertyName)

ForEach(string propertyName, object[] newValue)

Il ForEach() metodo può essere utilizzato anche per recuperare o impostare i valori delle proprietà per ogni elemento dell'insieme.

# Set all LastAccessTime properties of files to the current date.
(dir 'C:\Temp').ForEach('LastAccessTime', (Get-Date))
# View the newly set LastAccessTime of all items, and find Unique entries.
(dir 'C:\Temp').ForEach('LastAccessTime') | Get-Unique
Wednesday, June 20, 2018 9:21:57 AM

ForEach(string methodName)

ForEach(string methodName, object[] arguments)

Infine, ForEach() i metodi possono essere usati per eseguire un metodo su ogni elemento della raccolta.

("one", "two", "three").ForEach("ToUpper")
ONE
TWO
THREE

Proprio come il parametro ArgumentList di ForEach-Object, il arguments parametro consente il passaggio di una matrice di valori a un blocco di script configurato per accettarli.

Nota

A partire da Windows PowerShell 3.0, è possibile recuperare le proprietà ed eseguire metodi per ogni elemento di una raccolta usando anche "Metodi di oggetti e raccolte scalari". Per altre informazioni, vedere qui about_Methods.

Where()

Consente di filtrare o selezionare gli elementi della matrice. Lo script deve restituire valori diversi da zero (0), stringa $false vuota o $null per visualizzare l'elemento dopo .Where() Per altre informazioni sulla valutazione booleana, vedere about_Booleans.

Esiste una definizione per il Where() metodo .

Where(scriptblock expression[, WhereOperatorSelectionMode mode
                            [, int numberToReturn]])

Nota

La sintassi richiede l'utilizzo di un blocco di script. Le parentesi sono facoltative se lo scriptblock è l'unico parametro. Inoltre, non deve esistere uno spazio tra il metodo e la parentesi graffa di apertura.

Expression è un blocco di script necessario per il filtro, l'argomento mode facoltativo consente funzionalità di selezione aggiuntive e l'argomento numberToReturn facoltativo consente di limitare il numero di elementi restituiti dal filtro.

Il valore di mode deve essere un valore enumerazione WhereOperatorSelectionMode :

  • Default (0) - Restituisce tutti gli elementi
  • First(1) - Restituisce l'elemento first
  • Last(2) - Restituisce l'elemento last
  • SkipUntil (3) - La condizione Ignora elementi until è true, restituisce tutti gli elementi rimanenti (incluso l'elemento first per il quale la condizione è true)
  • Until (4) - Restituisce tutte le condizioni degli elementi until è true
  • Split (5) - Restituisce una matrice di due elementi
    • L'elemento first contiene elementi corrispondenti
    • Il secondo elemento contiene gli elementi rimanenti

Nell'esempio seguente viene illustrato come selezionare tutti i numeri dispari dalla matrice.

(0..9).Where{ $_ % 2 }
1
3
5
7
9

Nell'esempio seguente viene illustrato come selezionare tutte le stringhe non vuote.

('hi', '', 'there').Where{ $_ }
hi
there

Default

La Default modalità filtra gli elementi usando scriptblock Expression .

Se viene specificato un numberToReturn oggetto , specifica il numero massimo di elementi da restituire.

# Get the zip files in the current users profile, sorted by LastAccessTime
$Zips = dir $env:userprofile -Recurse '*.zip' | Sort-Object LastAccessTime
# Get the least accessed file over 100MB
$Zips.Where({$_.Length -gt 100MB}, 'Default', 1)

Nota

Sia la modalità che la Default modalità First restituiscono gli first elementi (numberToReturn) e possono essere usati in modo intercambiabile.

Last

$h = (Get-Date).AddHours(-1)
$logs = dir 'C:\' -Recurse '*.log' | Sort-Object CreationTime
# Find the last 5 log files created in the past hour
$logs.Where({$_.CreationTime -gt $h}, 'Last', 5)

SkipUntil

La SkipUntil modalità ignora tutti gli oggetti in una raccolta until a cui un oggetto passa il filtro dell'espressione del blocco di script. Restituisce quindi TUTTI gli elementi rimanenti della raccolta senza testarli. Viene testato un solo elemento passing.

Ciò significa che la raccolta restituita contiene sia elementi passati che non superati.

Il numero di elementi restituiti può essere limitato passando un valore all'argomento numberToReturn .

$computers = "Server01", "Server02", "Server03", "localhost", "Server04"
# Find the first available online server.
$computers.Where({ Test-Connection $_ }, 'SkipUntil', 1)
localhost

Until

La Until modalità inverte la SkipUntil modalità. Restituisce TUTTI gli elementi di una raccolta until che un elemento passa l'espressione del blocco di script. Quando un elemento passa l'espressione scriptblock, il metodo interrompe l'elaborazione Where() degli elementi.

Ciò significa che si riceve il first set di elementi non passati dal Where() metodo . Dopo il passaggio di un elemento, il resto non viene testato o restituito.

Il numero di elementi restituiti può essere limitato passando un valore all'argomento numberToReturn .

# Retrieve the first set of numbers less than or equal to 10.
(1..50).Where({$_ -gt 10}, 'Until')
# This would perform the same operation.
(1..50).Where({$_ -le 10})
1
2
3
4
5
6
7
8
9
10

Nota

Sia Until che SkipUntil operano in base al presupposto di NON testare un batch di elementi.

Until restituisce gli elementi BEFORE THE firstPASS. SkipUntil restituisce tutti gli elementi AFTER il firstpassaggio, incluso l'elemento first di passaggio.

Split

La Split modalità divide o raggruppa gli elementi della raccolta in due raccolte separate. Quelli che passano l'espressione scriptblock e quelli che non lo fanno.

Se viene specificato un numberToReturn oggetto , l'insieme first contiene gli elementi passati , non per superare il valore specificato.

Gli oggetti rimanenti, anche quelli che passano il filtro di espressione, vengono restituiti nella seconda raccolta.

$running, $stopped = (Get-Service).Where({$_.Status -eq 'Running'}, 'Split')
$running
Status   Name               DisplayName
------   ----               -----------
Running  Appinfo            Application Information
Running  AudioEndpointBu... Windows Audio Endpoint Builder
Running  Audiosrv           Windows Audio
...
$stopped
Status   Name               DisplayName
------   ----               -----------
Stopped  AJRouter           AllJoyn Router Service
Stopped  ALG                Application Layer Gateway Service
Stopped  AppIDSvc           Application Identity
...

Nota

Entrambi i ForEach() metodi e Where() sono membri intrinseci. Per altre informazioni sui membri intrinseci, vedere about_Intrinsic_Members.

Ottenere i membri di una matrice

Per ottenere le proprietà e i metodi di una matrice, ad esempio la Length proprietà e il metodo SetValue , utilizzare il parametro InputObject del Get-Member cmdlet .

Quando si invia tramite pipe una matrice a Get-Member, PowerShell invia gli elementi uno alla volta e Get-Member restituisce il tipo di ogni elemento nella matrice (ignorando i duplicati).

Quando si usa il parametro InputObject , Get-Member restituisce i membri della matrice.

Ad esempio, il comando seguente ottiene i membri della variabile di $a matrice.

Get-Member -InputObject $a

È anche possibile ottenere i membri di una matrice digitando una virgola (,) prima del valore inviato tramite pipe al Get-Member cmdlet. La virgola rende la matrice il secondo elemento in una matrice di matrici. PowerShell invia tramite pipe le matrici una alla volta e Get-Member restituisce i membri della matrice. Come i due esempi successivi.

,$a | Get-Member

,(1,2,3) | Get-Member

Modifica di una matrice

È possibile modificare gli elementi in una matrice, aggiungere un elemento a una matrice e combinare i valori di due matrici in una terza matrice.

Per modificare il valore di un particolare elemento in una matrice, specificare il nome della matrice e l'indice dell'elemento da modificare e quindi usare l'operatore di assegnazione (=) per specificare un nuovo valore per l'elemento. Ad esempio, per modificare il valore del secondo elemento nella $a matrice (posizione di indice 1) su 10, digitare:

$a[1] = 10

È anche possibile usare il metodo SetValue di una matrice per modificare un valore. Nell'esempio seguente il secondo valore (posizione di indice 1) della $a matrice viene modificato in 500:

$a.SetValue(500,1)

È possibile usare l'operatore += per aggiungere un elemento a una matrice. Nell'esempio seguente viene illustrato come aggiungere un elemento alla $a matrice.

$a = @(0..4)
$a += 5

Nota

Quando si usa l'operatore += , PowerShell crea effettivamente una nuova matrice con i valori della matrice originale e il valore aggiunto. Ciò può causare problemi di prestazioni se l'operazione viene ripetuta più volte o le dimensioni della matrice sono troppo grandi.

Non è facile eliminare elementi da una matrice, ma è possibile creare una nuova matrice contenente solo elementi selezionati di una matrice esistente. Ad esempio, per creare la $t matrice con tutti gli elementi nella $a matrice, ad eccezione del valore in corrispondenza della posizione di indice 2, digitare:

$t = $a[0,1 + 3..($a.length - 1)]

Per combinare due matrici in una singola matrice, usare l'operatore più (+). L'esempio seguente crea due matrici, le combina e quindi visualizza la matrice combinata risultante.

$x = 1,3
$y = 5,9
$z = $x + $y

Di conseguenza, la $z matrice contiene 1, 3, 5 e 9.

Per eliminare una matrice, assegnare un valore alla $null matrice. Il comando seguente elimina la matrice nella $a variabile .

$a = $null

È anche possibile usare il Remove-Item cmdlet , ma l'assegnazione di un valore è $null più veloce, soprattutto per le matrici di grandi dimensioni.

Matrici pari a zero o uno

A partire da Windows PowerShell 3.0, una raccolta di zero o un oggetto ha le Count proprietà e Length . È anche possibile indicizzare in una matrice di un oggetto. Questa funzionalità consente di evitare errori di scripting che si verificano quando un comando che prevede che una raccolta ottenga meno di due elementi.

Nota

In Windows PowerShell gli oggetti creati eseguendo il cast di una tabella Hash per [pscustomobject] non hanno le Length proprietà o Count . Il tentativo di accedere a questi membri restituisce $null.

Nell'esempio seguente viene illustrato che una variabile che non contiene oggetti ha e Count Length 0.

PS> $a = $null
PS> $a.Count
0
PS> $a.Length
0

Nell'esempio seguente viene illustrato che una variabile che contiene un oggetto ha e Count Length 1. È anche possibile usare l'indicizzazione di matrici per accedere al valore dell'oggetto .

PS> $a = 4
PS> $a.Count
1
PS> $a.Length
1
PS> $a[0]
4
PS> $a[-1]
4

Quando si esegue un comando che potrebbe restituire una raccolta o un singolo oggetto, è possibile utilizzare l'indicizzazione di matrici per accedere al valore dell'oggetto senza dover testare le Count proprietà o Length . Tuttavia, se il risultato è un singolo oggetto (singleton) e tale oggetto ha una Count proprietà o Length , il valore di tali proprietà appartiene all'oggetto singleton e non rappresenta il numero di elementi nell'insieme.

Nell'esempio seguente il comando restituisce un singolo oggetto stringa. L'oggetto Length di tale stringa è 4.

PS> $result = 'one','two','three','four' | Where-Object {$_ -like 'f*'}
PS> $result.GetType().FullName
System.String
PS> $result
four
PS> $result.Count
1
PS❯ $result.Length
4

Se si vuole $result essere una matrice di stringhe, è necessario dichiarare la variabile come matrice.

In questo esempio è $result una matrice di stringhe. E Count Length della matrice è 1e l'oggetto Length dell'elemento first è 4.

PS> [string[]]$result = 'one','two','three','four' |
    Where-Object {$_ -like 'f*'}
PS> $result.GetType().FullName
System.String[]
PS> $result
four
PS> $result.Count
1
PS> $result.Length
1
PS> $result[0].Length
4

Indicizzazione di tipi .NET che implementano IDictionary<TKey, TValue>

PowerShell non chiama l'indicizzatore vero di un tipo per i tipi che implementano l'interfaccia generica IDictionary<TKey, TValue> . Quando viene specificata una chiave, PowerShell verifica invece l'esistenza della chiave usando TryGetValue(), che restituisce $null quando la chiave non esiste.

Al contrario, se si chiama l'indicizzatore true del tipo usando Item(<key>), il metodo genera un'eccezione quando la chiave non esiste.

Nell'esempio che segue viene illustrata la differenza.

PS> [Collections.Generic.Dictionary[string, int]]::new()['nosuchkey']
# No output ($null)

PS> [Collections.Generic.Dictionary[string, int]]::new().Item('nosuchkey')
Exception getting "Item": "The given key 'nosuchkey' was not present in the dictionary."
At line:1 char:1
+ [Collections.Generic.Dictionary[string, int]]::new().Item('nosuchkey' ...
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo          : NotSpecified: (:) [], GetValueInvocationException
+ FullyQualifiedErrorId : ExceptionWhenGetting

Enumerazione member-access

A partire da PowerShell 3.0, quando si usa l'operatore di accesso ai membri per accedere a un membro che non esiste in una raccolta di elenchi, PowerShell enumera automaticamente gli elementi nella raccolta e tenta di accedere al membro specificato in ogni elemento. Per altre informazioni, vedere about_Member-Access_Enumeration.

Esempi

Nell'esempio seguente vengono creati due nuovi file e vengono archiviati gli oggetti risultanti nella variabile $filesdi matrice . Poiché l'oggetto matrice non ha il membro LastWriteTime , viene restituito il valore di LastWriteTime per ogni elemento della matrice.

$files = (New-Item -Type File -Force '/temp/t1.txt'),
         (New-Item -Force -Type File '/temp/t2.txt')
$files.LastWriteTime
Friday, June 25, 2021 1:21:17 PM
Friday, June 25, 2021 1:21:17 PM

L'enumerazione di accesso ai membri consente di ottenere valori dagli elementi di una raccolta, ma non di impostare valori sugli elementi di una raccolta. Ad esempio:

$files.LastWriteTime = (Get-Date).AddDays(-1)
The property 'LastWriteTime' cannot be found on this object. Verify that the
property exists and can be set.
At line:1 char:1
+ $files.LastWriteTime = (Get-Date).AddDays(-1)
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : InvalidOperation: (:) [], RuntimeException
    + FullyQualifiedErrorId : PropertyAssignmentException

Per impostare i valori è necessario utilizzare un metodo .

$files.set_LastWriteTime((Get-Date).AddDays(-1))
$files.LastWriteTime
Thursday, June 24, 2021 1:23:30 PM
Thursday, June 24, 2021 1:23:30 PM

Il set_LastWriteTime() metodo è un membro nascosto dell'oggetto FileInfo . Nell'esempio seguente viene illustrato come trovare metodi nascostiset.

$files | Get-Member -Force -Name set_*
   TypeName: System.IO.FileInfo

Name              MemberType Definition
----              ---------- ----------
Attributes        Property   System.IO.FileAttributes Attributes {get;set;}
CreationTime      Property   datetime CreationTime {get;set;}
CreationTimeUtc   Property   datetime CreationTimeUtc {get;set;}
IsReadOnly        Property   bool IsReadOnly {get;set;}
LastAccessTime    Property   datetime LastAccessTime {get;set;}
LastAccessTimeUtc Property   datetime LastAccessTimeUtc {get;set;}
LastWriteTime     Property   datetime LastWriteTime {get;set;}
LastWriteTimeUtc  Property   datetime LastWriteTimeUtc {get;set;}

Attenzione

Poiché il metodo viene eseguito per ogni elemento della raccolta, è necessario prestare attenzione quando si chiamano i metodi usando l'enumerazione dei membri.

Vedi anche