Freigeben über


Informationen zu Skriptblöcken

Kurze Beschreibung

Definiert, was ein Skriptblock ist, und erläutert, wie Skriptblöcke in der Programmiersprache PowerShell verwendet werden.

Lange Beschreibung

In der Programmiersprache PowerShell ist ein Skriptblock eine Sammlung von Anweisungen oder Ausdrücken, die als einzelne Einheit verwendet werden können. Ein Skriptblock kann Argumente und Rückgabewerte akzeptieren.

Syntaktisch ist ein Skriptblock eine Anweisungsliste in geschweiften Klammern, wie in der folgenden Syntax gezeigt:

{<statement list>}

Ein Skriptblock gibt die Ausgabe aller Befehle im Skriptblock zurück, entweder als einzelnes Objekt oder als Array.

Sie können auch mithilfe der return Schlüsselwort (keyword) einen Rückgabewert angeben. Die return Schlüsselwort (keyword) wirkt sich nicht auf andere Ausgaben aus dem Skriptblock aus oder unterdrückt sie nicht. Der return Schlüsselwort (keyword) beendet jedoch den Skriptblock in dieser Zeile. Weitere Informationen finden Sie unter about_Return.

Wie Funktionen kann ein Skriptblock Parameter enthalten. Verwenden Sie die Param-Schlüsselwort (keyword), um benannte Parameter zuzuweisen, wie in der folgenden Syntax gezeigt:

{
Param([type]$Parameter1 [,[type]$Parameter2])
<statement list>
}

Hinweis

In einem Skriptblock können Sie im Gegensatz zu einer Funktion keine Parameter außerhalb der geschweiften Klammern angeben.

Wie Funktionen können Skriptblöcke die DynamicParamSchlüsselwörter , Begin, Processund End enthalten. Weitere Informationen finden Sie unter about_Functions und about_Functions_Advanced.

Verwenden von Skriptblöcken

Ein Skriptblock ist eine instance eines Microsoft .NET Framework Typs System.Management.Automation.ScriptBlock. Befehle können Skriptblockparameterwerte aufweisen. Das Cmdlet verfügt beispielsweise über einen ScriptBlock Parameter, der Invoke-Command einen Skriptblockwert annimmt, wie in diesem Beispiel gezeigt:

Invoke-Command -ScriptBlock { Get-Process }
Handles  NPM(K)    PM(K)     WS(K) VM(M)   CPU(s)     Id ProcessName
-------  ------    -----     ----- -----   ------     -- -----------
999          28    39100     45020   262    15.88   1844 communicator
721          28    32696     36536   222    20.84   4028 explorer
...

Invoke-Command kann auch Skriptblöcke mit Parameterblöcken ausführen. Parameter werden mithilfe des ArgumentList-Parameters nach Position zugewiesen.

Invoke-Command -ScriptBlock { param($p1, $p2)
"p1: $p1"
"p2: $p2"
} -ArgumentList "First", "Second"
p1: First
p2: Second

Der Skriptblock im vorherigen Beispiel verwendet die param Schlüsselwort (keyword), um parameter $p1 und $p2zu erstellen. Die Zeichenfolge "First" ist an den ersten Parameter ($p1) und "Second" an ($p2) gebunden.

Weitere Informationen zum Verhalten von ArgumentList finden Sie unter about_Splatting.

Sie können Variablen verwenden, um Skriptblöcke zu speichern und auszuführen. Im folgenden Beispiel wird ein Skriptblock in einer Variablen gespeichert und an Invoke-Commandübergeben.

$a = { Get-Service BITS }
Invoke-Command -ScriptBlock $a
Status   Name               DisplayName
------   ----               -----------
Running  BITS               Background Intelligent Transfer Ser...

Der Aufrufoperator ist eine weitere Möglichkeit zum Ausführen von Skriptblöcken, die in einer Variablen gespeichert sind. Wie Invoke-Commandführt der Aufrufoperator den Skriptblock in einem untergeordneten Bereich aus. Der Aufrufoperator kann ihnen die Verwendung von Parametern mit Ihren Skriptblöcken erleichtern.

$a ={ param($p1, $p2)
"p1: $p1"
"p2: $p2"
}
&$a -p2 "First" -p1 "Second"
p1: Second
p2: First

Sie können die Ausgabe Ihrer Skriptblöcke mithilfe der Zuweisung in einer Variablen speichern.

PS>  $a = { 1 + 1}
PS>  $b = &$a
PS>  $b
2
PS>  $a = { 1 + 1}
PS>  $b = Invoke-Command $a
PS>  $b
2

Weitere Informationen zum Aufrufoperator finden Sie unter about_Operators.

Verwenden von Verzögerungsbindungsskriptblöcken mit Parametern

Ein typisierter Parameter, der pipelineeingaben (by Value) oder (by PropertyName) akzeptiert, ermöglicht die Verwendung von Verzögerungsbindungsskriptblöcken für den Parameter. Innerhalb des Verzögerungsbindungsskriptblocks können Sie mithilfe der Pipelinevariable $_auf das in die Pipeline übergebene Objekt verweisen.

# Renames config.log to old_config.log
dir config.log | Rename-Item -NewName {"old_" + $_.Name}

In komplexeren Cmdlets ermöglichen Verzögerungsbindungsskriptblöcke die Wiederverwendung eines objekts, das in die Pipeline übergeben wurde, um andere Parameter aufzufüllen.

Hinweise zu verzögerten Skriptblöcken als Parameter:

  • Sie müssen explizit alle Parameternamen angeben, die Sie mit Verzögerungsbindungsskriptblöcken verwenden.

  • Der Parameter darf nicht untypisiert sein, und der Typ des Parameters darf nicht oder [object]sein[scriptblock].

  • Sie erhalten eine Fehlermeldung, wenn Sie einen Verzögertbindungsskriptblock verwenden, ohne eine Pipelineeingabe bereitzustellen.

    Rename-Item -NewName {$_.Name + ".old"}
    
    Rename-Item : Cannot evaluate parameter 'NewName' because its argument is
    specified as a script block and there is no input. A script block cannot
    be evaluated without input.
    At line:1 char:23
    +  Rename-Item -NewName {$_.Name + ".old"}
    +                       ~~~~~~~~~~~~~~~~~~
        + CategoryInfo          : MetadataError: (:) [Rename-Item],
          ParameterBindingException
        + FullyQualifiedErrorId : ScriptBlockArgumentNoInput,
          Microsoft.PowerShell.Commands.RenameItemCommand
    

Weitere Informationen

about_Functions

about_Functions_Advanced

about_Operators