about_Variables
Kurze Beschreibung
Beschreibt, wie Variablen Werte speichern, die in PowerShell verwendet werden können.
Lange Beschreibung
Sie können alle Typen von Werten in PowerShell-Variablen speichern. Speichern Sie beispielsweise die Ergebnisse von Befehlen, und speichern Sie Elemente, die in Befehlen und Ausdrücken verwendet werden, z. B. Namen, Pfade, Einstellungen und Werte.
Eine Variable ist eine Speichereinheit, in der Werte gespeichert werden. In PowerShell werden Variablen durch Textzeichenfolgen dargestellt, die mit einem Dollarzeichen ($
), z$a
. B. , oder .$process
$my_var
Variablennamen werden nicht zwischen Groß- und Kleinschreibung unterschieden und können Leerzeichen und Sonderzeichen enthalten. Variablennamen, die Sonderzeichen und Leerzeichen enthalten, sind jedoch schwer zu verwenden und sollten vermieden werden. Weitere Informationen finden Sie unter Variablennamen, die Sonderzeichen enthalten.
Es gibt verschiedene Arten von Variablen in PowerShell.
Vom Benutzer erstellte Variablen: Vom Benutzer erstellte Variablen werden vom Benutzer erstellt und verwaltet. Standardmäßig sind die Variablen, die Sie in der PowerShell-Befehlszeile erstellen, nur vorhanden, wenn das PowerShell-Fenster geöffnet ist. Wenn die PowerShell-Fenster geschlossen werden, werden die Variablen gelöscht. Um eine Variable zu speichern, fügen Sie sie Ihrem PowerShell-Profil hinzu. Sie können variablen auch in Skripts mit globaler, skript- oder lokaler Bereich erstellen.
Automatische Variablen: Automatische Variablen speichern den Status von PowerShell. Diese Variablen werden von PowerShell erstellt, und PowerShell ändert ihre Werte nach Bedarf, um ihre Genauigkeit aufrechtzuerhalten. Benutzer können den Wert dieser Variablen nicht ändern. Beispielsweise speichert die
$PSHOME
Variable den Pfad zum PowerShell-Installationsverzeichnis.Weitere Informationen, eine Liste und eine Beschreibung der automatischen Variablen finden Sie unter about_Automatic_Variables.
Einstellungsvariablen: Einstellungsvariablen speichern Benutzereinstellungen für PowerShell. Diese Variablen werden von PowerShell erstellt und mit Standardwerten aufgefüllt. Benutzer können die Werte dieser Variablen ändern. Die Variable bestimmt beispielsweise
$MaximumHistoryCount
die maximale Anzahl von Einträgen im Sitzungsverlauf.Weitere Informationen, eine Liste und eine Beschreibung der Einstellungsvariablen finden Sie unter about_Preference_Variables.
Arbeiten mit Variablen
Verwenden Sie zum Erstellen einer neuen Variablen eine Zuweisungsanweisung, um der Variablen einen Wert zuzuweisen. Sie müssen die Variable nicht deklarieren, bevor Sie sie verwenden. Der Standardwert aller Variablen ist $null
.
Wenn Sie eine Liste aller Variablen in Ihrer PowerShell-Sitzung abrufen möchten, geben Sie folgendes ein Get-Variable
. Die Variablennamen werden ohne das vorangehende Dollarzeichen ($
) angezeigt, das zum Verweisen auf Variablen verwendet wird.
Zum Beispiel:
$MyVariable = 1, 2, 3
$Path = "C:\Windows\System32"
Variablen sind nützlich, um die Ergebnisse von Befehlen zu speichern.
Zum Beispiel:
$Processes = Get-Process
$Today = (Get-Date).DateTime
Um den Wert einer Variablen anzuzeigen, geben Sie den Variablennamen ein, dem ein Dollarzeichen ($
) vorangestellt ist.
Zum Beispiel:
$MyVariable
1
2
3
$Today
Tuesday, September 3, 2019 09:46:46
Um den Wert einer Variablen zu ändern, weisen Sie der Variablen einen neuen Wert zu.
In den folgenden Beispielen wird der Wert der $MyVariable
Variablen angezeigt, der Wert der Variablen geändert und anschließend der neue Wert angezeigt.
$MyVariable = 1, 2, 3
$MyVariable
1
2
3
$MyVariable = "The green cat."
$MyVariable
The green cat.
Um den Wert einer Variablen zu löschen, verwenden Sie das Clear-Variable
Cmdlet, oder ändern Sie den Wert in $null
.
Clear-Variable -Name MyVariable
$MyVariable = $null
Verwenden Sie "Remove-Variable " oder "Remove-Item", um die Variable zu löschen.
Remove-Variable -Name MyVariable
Remove-Item -Path Variable:\MyVariable
Es ist auch möglich, mehreren Variablen Mit einer Anweisung Werte zuzuweisen. In den folgenden Beispielen wird mehreren Variablen derselbe Wert zugewiesen:
$a = $b = $c = 0
Im nächsten Beispiel werden mehreren Variablen mehrere Werte zugewiesen.
$i,$j,$k = 10, "red", $true # $i is 10, $j is "red", $k is True
$i,$j = 10, "red", $true # $i is 10, $j is [object[]], Length 2
Ausführlichere Informationen finden Sie im Abschnitt "Zuweisen mehrerer Variablen " von about_Assignment_Operators.
Typen von Variablen
Sie können jeden Objekttyp in einer Variablen speichern, einschließlich ganzzahliger Zahlen, Zeichenfolgen, Arrays und Hashtabellen. Und Objekte, die Prozesse, Dienste, Ereignisprotokolle und Computer darstellen.
PowerShell-Variablen sind lose typiert, was bedeutet, dass sie nicht auf einen bestimmten Objekttyp beschränkt sind. Eine einzelne Variable kann sogar eine Auflistung oder ein Array unterschiedlicher Objekttypen gleichzeitig enthalten.
Der Datentyp einer Variablen wird durch die .NET-Typen der Werte der Variablen bestimmt. Verwenden Sie "Get-Member", um den Objekttyp einer Variablen anzuzeigen.
Zum Beispiel:
$a = 12 # System.Int32
$a = "Word" # System.String
$a = 12, "Word" # array of System.Int32, System.String
$a = Get-ChildItem C:\Windows # FileInfo and DirectoryInfo types
Sie können ein Typattribute und eine Umwandlungsnotation verwenden, um sicherzustellen, dass eine Variable nur bestimmte Objekttypen oder Objekte enthalten kann, die in diesen Typ konvertiert werden können. Wenn Sie versuchen, einen Wert eines anderen Typs zuzuweisen, versucht PowerShell, den Wert in seinen Typ zu konvertieren. Wenn der Typ nicht konvertiert werden kann, schlägt die Zuordnungsanweisung fehl.
Wenn Sie die Umwandlungsnotation verwenden möchten, geben Sie einen Typnamen ein, der in eckige Klammern eingeschlossen ist, vor dem Variablennamen (auf der linken Seite der Zuordnungsanweisung). Im folgenden Beispiel wird eine $number
Variable erstellt, die nur ganze Zahlen, eine $words
Variable, die nur Zeichenfolgen enthalten kann, und eine $dates
Variable, die nur DateTime-Objekte enthalten kann.
[int]$number = 8
$number = "12345" # The string is converted to an integer.
$number = "Hello"
Cannot convert value "Hello" to type "System.Int32". Error: "Input string
was not in a correct format."
At line:1 char:1
+ $number = "Hello"
+ ~~~~~~~~~~~~~~~~~
+ CategoryInfo : MetadataError: (:) [],
ArgumentTransformationMetadataException
+ FullyQualifiedErrorId : RuntimeException
[string]$words = "Hello"
$words = 2 # The integer is converted to a string.
$words += 10 # The plus (+) sign concatenates the strings.
$words
210
[datetime] $dates = "09/12/91" # The string is converted to a DateTime object.
$dates
Thursday, September 12, 1991 00:00:00
$dates = 10 # The integer is converted to a DateTime object.
$dates
Monday, January 1, 0001 00:00:00
Verwenden von Variablen in Befehlen und Ausdrücken
Wenn Sie eine Variable in einem Befehl oder Ausdruck verwenden möchten, geben Sie den Variablennamen ein, dem das Dollarzeichen ($
) vorangestellt ist.
Wenn der Variablenname und das Dollarzeichen nicht in Anführungszeichen eingeschlossen sind oder in doppelte Anführungszeichen ("
) eingeschlossen sind, wird der Wert der Variablen im Befehl oder Ausdruck verwendet.
Wenn der Variablenname und das Dollarzeichen in einfache Anführungszeichen ('
) eingeschlossen sind, wird der Variablenname im Ausdruck verwendet.
Weitere Informationen zur Verwendung von Anführungszeichen in PowerShell finden Sie unter about_Quoting_Rules.
In diesem Beispiel wird der Wert der $PROFILE
Variablen abgerufen, bei der es sich um den Pfad zur PowerShell-Benutzerprofildatei in der PowerShell-Konsole handelt.
$PROFILE
C:\Users\User01\Documents\PowerShell\Microsoft.PowerShell_profile.ps1
In diesem Beispiel werden zwei Befehle gezeigt, die das PowerShell-Profil in notepad.exe öffnen können. Das Beispiel mit Anführungszeichen ("
Double-Anführungszeichen) verwendet den Wert der Variablen.
notepad $PROFILE
notepad "$PROFILE"
In den folgenden Beispielen werden Einfache Anführungszeichen ('
) verwendet, die die Variable als Literaltext behandeln.
'$PROFILE'
$PROFILE
'Use the $PROFILE variable.'
Use the $PROFILE variable.
Variablennamen, die Sonderzeichen enthalten
Variablennamen beginnen mit einem Dollarzeichen ($
) und können alphanumerische Zeichen und Sonderzeichen enthalten. Die Länge des Variablennamens ist nur durch den verfügbaren Arbeitsspeicher begrenzt.
Die bewährte Methode besteht darin, dass Variablennamen nur alphanumerische Zeichen und das Unterstrichzeichen (_
) enthalten. Variablennamen, die Leerzeichen und andere Sonderzeichen enthalten, sind schwer zu verwenden und sollten vermieden werden.
Alphanumerische Variablennamen können folgende Zeichen enthalten:
- Unicode-Zeichen aus diesen Kategorien: Lu, Ll, Lt, Lm, Lo oder Nd.
- Unterstrich (
_
) Zeichen. - Fragezeichen (
?
)
Die folgende Liste enthält die .NET-Namen der Unicode-Kategorien mit einer Beschreibung. Weitere Informationen finden Sie unter UnicodeCategory.
- Lu – UppercaseLetter – ein Großbuchstabe
- Ll – LowercaseLetter – ein Kleinbuchstabe
- Lt – TitlecaseLetter – ein Digraph, der als einzelnes Zeichen kodiert ist, wobei das erste Element ein Großbuchstabe ist
- Lm – ModifierLetter – ein Modifizierungsbuchstabe
- Lo – OtherLetter – andere Buchstaben, einschließlich Silben und Ideogramme
- Nd – DecimalDigitNumber – eine Dezimalziffer
Wenn Sie einen Variablennamen erstellen oder anzeigen möchten, der Leerzeichen oder Sonderzeichen enthält, schließen Sie den Variablennamen in die geschweiften Klammern ({}
) ein.
Die geschweiften geschweiften Klammern leiten PowerShell aus, um die Zeichen des Variablennamens als Literale zu interpretieren.
Sonderzeichenvariablennamen können folgende Zeichen enthalten:
- Jedes Unicode-Zeichen mit den folgenden Ausnahmen:
- Das schließende geschweifte Klammerzeichen (
}
) (U+007D). - Das Hintergrundzeichen () (
`
U+0060). Der Backtick wird verwendet, um Unicode-Zeichen zu escapen, sodass sie als Literale behandelt werden.
- Das schließende geschweifte Klammerzeichen (
PowerShell verfügt über reservierte Variablen wie $$
, $?
, $^
und $_
die alphanumerische und Sonderzeichen enthalten. Weitere Informationen finden Sie unter about_Automatic_Variables.
Mit dem folgenden Befehl wird beispielsweise die Variable mit dem Namen save-items
erstellt. Die geschweiften geschweiften Klammern ({}
) sind erforderlich, da der Variablenname ein Bindestrich () Sonderzeichen enthält-
.
${save-items} = "a", "b", "c"
${save-items}
a
b
c
Der folgende Befehl ruft die untergeordneten Elemente im Verzeichnis ab, das durch die ProgramFiles(x86)
Umgebungsvariable dargestellt wird.
Get-ChildItem ${env:ProgramFiles(x86)}
Um auf einen Variablennamen zu verweisen, der geschweifte Klammern enthält, schließen Sie den Variablennamen in geschweifte Klammern ein, und verwenden Sie das Backtick-Zeichen, um die geschweiften Klammern zu escapen. So erstellen Sie z. B. eine Variable namens this{value}is
Typ:
${this`{value`}is} = "This variable name uses braces and backticks."
${this`{value`}is}
This variable name uses braces and backticks.
Variablen und Bereich
Standardmäßig sind Variablen nur in dem Bereich verfügbar, in dem sie erstellt werden.
Beispielsweise ist eine Variable, die Sie in einer Funktion erstellen, nur innerhalb der Funktion verfügbar. Eine Variable, die Sie in einem Skript erstellen, ist nur innerhalb des Skripts verfügbar. Wenn Sie das Skript punktieren, wird die Variable dem aktuellen Bereich hinzugefügt. Weitere Informationen finden Sie unter about_Scopes.
Sie können einen Bereichsmodifizierer verwenden, um den Standardumfang der Variablen zu ändern. Der folgende Ausdruck erstellt eine Variable mit dem Namen Computers
. Die Variable hat einen globalen Bereich, auch wenn sie in einem Skript oder einer Funktion erstellt wird.
$Global:Computers = "Server01"
Für alle Skripts oder Befehle, die außerhalb der Sitzung ausgeführt werden, benötigen Sie den Using
Bereichsmodifizierer, um Variablenwerte aus dem aufrufenden Sitzungsbereich einzubetten, damit außerhalb des Sitzungscodes darauf zugegriffen werden kann.
Weitere Informationen finden Sie unter about_Remote_Variables.
Speichern von Variablen
Variablen, die Sie erstellen, sind nur in der Sitzung verfügbar, in der Sie sie erstellen. Sie gehen verloren, wenn Sie Ihre Sitzung schließen.
Um die Variable in jeder powerShell-Sitzung zu erstellen, die Sie starten, fügen Sie die Variable ihrem PowerShell-Profil hinzu.
Um beispielsweise den Wert der $VerbosePreference
Variablen in jeder PowerShell-Sitzung zu ändern, fügen Sie Ihrem PowerShell-Profil den folgenden Befehl hinzu.
$VerbosePreference = "Continue"
Sie können diesen Befehl ihrem PowerShell-Profil hinzufügen, indem Sie die $PROFILE
Datei in einem Text-Editor öffnen, z . B. notepad.exe. Weitere Informationen über PowerShell-Profile finden Sie unter about_Profiles.
Die Variable: Laufwerk
Der PowerShell-Variable-Anbieter erstellt ein Variable:
Laufwerk, das wie ein Dateisystemlaufwerk aussieht und funktioniert, enthält jedoch die Variablen in Ihrer Sitzung und deren Werte.
Verwenden Sie den folgenden Befehl, um zum Variable:
Laufwerk zu wechseln:
Set-Location Variable:
Verwenden Sie Variable:
die Oder-CmdletsGet-Item
, um die Elemente und Variablen auf dem Get-ChildItem
Laufwerk aufzulisten.
Get-ChildItem Variable:
Verwenden Sie zum Abrufen des Werts einer bestimmten Variablen die Dateisystemnotation, um den Namen des Laufwerks und den Namen der Variablen anzugeben. Verwenden Sie beispielsweise den folgenden Befehl, um die $PSCulture
automatische Variable abzurufen.
Get-Item Variable:\PSCulture
Name Value
---- -----
PSCulture en-US
Um weitere Informationen zum Variable:
Laufwerk und zum PowerShell-Variablenanbieter anzuzeigen, geben Sie Folgendes ein:
Get-Help Variable
Variable Syntax mit Anbieterpfaden
Sie können einem Anbieterpfad das Dollarzeichen ($
) voranstellen und auf den Inhalt eines beliebigen Anbieters zugreifen, der die IContentCmdletProvider-Schnittstelle implementiert.
Die folgenden integrierten PowerShell-Anbieter unterstützen diese Schreibweise:
Die Variablen-Cmdlets
PowerShell enthält eine Reihe von Cmdlets, die zum Verwalten von Variablen konzipiert sind.
Geben Sie Folgendes ein, um die Cmdlets aufzulisten:
Get-Command -Noun Variable
Um Hilfe zu einem bestimmten Cmdlet zu erhalten, geben Sie Folgendes ein:
Get-Help <cmdlet-name>
Cmdlet-Name | Beschreibung |
---|---|
Clear-Variable |
Löscht den Wert einer Variablen. |
Get-Variable |
Ruft die Variablen in der aktuellen Konsole ab. |
New-Variable |
Erstellt einer neuen Variable. |
Remove-Variable |
Löscht eine Variable und ihren Wert. |
Set-Variable |
Ändert den Wert einer Variablen. |