Powershell: Pipelining

Z MiS
(Rozdíly mezi verzemi)
Přejít na: navigace, hledání
(Upraveno formátování.)
m (Filtrování: Doplněna možnost zkracování -Filter jako výchozí parametr.)
(Není zobrazeno 5 mezilehlých verzí od 1 uživatele.)
Řádka 18: Řádka 18:
 
== Zpracování ==
 
== Zpracování ==
  
  | Get-Methods
+
  | Get-Member
 
* Zjištění vlastností objektu, který dostane na vstupu.
 
* Zjištění vlastností objektu, který dostane na vstupu.
 
* Mohu využít jako pomocnou metodu pro zjištění, s jakými objekty pracuji.
 
* Mohu využít jako pomocnou metodu pro zjištění, s jakými objekty pracuji.
Řádka 45: Řádka 45:
  
 
  | Measure
 
  | Measure
*Počítá počet řádků
+
* Zjistí počet objektů na výstupu commandletu.
 
<div class="Priklad">
 
<div class="Priklad">
 
  Get-Verb | Measure
 
  Get-Verb | Measure
 
</div>
 
</div>
 
  
 
== Filtrování ==
 
== Filtrování ==
  | Where-object
+
  | Where-Object
| Where
+
* Commandlet pro obecné filtrování.
$_
+
* Aliasy: <code>Where</code>
*Zastupuje aktuální objekt z kolekce
+
 
Get-Service | Where {$_.status = "Running"}
+
* <code>-FilterScript {''...''}</code>
{...}
+
** Je default parametr, takže stačí i: <code> {''...''}</code>
* Spustí kód v závorkách.
+
** Spustí kód v závorkách.
* Pokud vrací $true, ponechá objekt v kolekci
+
** Pokud spuštěný kód vrací pro daný objekt <code>$false</code>, <code>$null</code> nebo <code>""</code>, zahodí objekt. Jinak objekt ponechá v&nbsp;kolekci.
* Pokud vrací $false, zahodí objekt
+
 
 +
* Lze využít: <code>$_</code>
 +
** Zastupuje aktuální objekt z kolekce.
 +
** Můžeme pracovat s&nbsp;vlastnostmi tohoto objektu.
 +
<div class="Priklad">
 +
Get-Service | Where {$_.Status -eq "Running"}
 +
</div>
 +
 
 +
* <code>-Property ''Vlastnost'' ''operátor'' ''Hodnota''</code>
 +
** Je default parametr, takže stačí i: <code>''Vlastnost'' ''operátor'' ''Hodnota''</code>
 +
<div class="Priklad">
 +
Get-Service | Where Status -eq "Running"
 +
</div>
  
 
; Operátory
 
; Operátory
Řádka 76: Řádka 87:
 
* Nejprve filtruj, pak zpracovávej! (Podobně jako v&nbsp;SQL.)
 
* Nejprve filtruj, pak zpracovávej! (Podobně jako v&nbsp;SQL.)
 
* Optimalizace výkonu.
 
* Optimalizace výkonu.
; Zjednodušená syntaxe
 
| Where podmínka
 
| Where Status="Running"
 
Get-ChildItem | Where Name -like "*.xls"
 
  
 +
; Pro filtrování je lépe použít parametr <code>-Filter</code>
 +
* Ale ne všechny příkazy ho mají.
 +
<div class="Priklad">
 +
Místo:
 +
Get-ChildItem | Where Name -like "*.xls"
 +
Můžeme tedy psát:
 +
Get-ChildItem -Filter "*.xls"
 +
Nebo dokonce:
 +
Get_ChildItem *.xls
 +
</div>
  
 
== Výstup do souboru ==
 
== Výstup do souboru ==
Řádka 89: Řádka 106:
 
*Commandlety mají v nápovědě informaci, jestli přijímají vstup z&nbsp;pipeline.
 
*Commandlety mají v nápovědě informaci, jestli přijímají vstup z&nbsp;pipeline.
  
; Přijímání vstupu
+
=== Přijímání vstupu ===
*by value
+
* by value
**Přímo předáváme objekty
+
** Přímo předáváme objekty.
**Typ objektů si musí odpovídat.
+
** Typ objektů na výstupu prvního commandletu musí odpovídat typu objektu, který očekává na vstupu zpracovávající commandlet.
*by Property Name
+
* by Property Name
  Get-Process calc | dir
+
** Přijímající commandlet očekává objekt, který má konkrétní vlastnost.
 +
** Na samotném typu předávaného objektu nezáleží, důležité je, že má tuto konkrétní vlastnost.
 +
<div class="Priklad">
 +
  Get-Process ''calc'' | dir
 
*Spusť předtím kalkulačku
 
*Spusť předtím kalkulačku
*Zobrazí obsah adresáře, ve kterém je program, který realizuje proces Calc
+
*Zobrazí obsah adresáře, ve kterém je program, který realizuje proces Calc.
 +
</div>
  
; Předávání počítačů
+
=== Předávání počítačů ===
* Příklad: <code>Get-ADComputers</code>
+
* Počítače nelze předávat jako objekty přímo.
** Počítače nelze předávat jako objekty přímo.
+
 
** Lze použít <code>{...}</code>:
+
; Lze použít <code>{...}</code>:
 
<div class="Priklad">
 
<div class="Priklad">
 
  Get-ADComputers -Filter * | Get-WMIObjects -class Win32_bios -ComputerName {$_.Name}
 
  Get-ADComputers -Filter * | Get-WMIObjects -class Win32_bios -ComputerName {$_.Name}
 
</div>
 
</div>
* Mnoho příkazů umí také:
+
 
** <code>-ComputerName</code>
+
; Mnoho příkazů umí také:
 +
* <code>-ComputerName</code>
 
<div class="Priklad">
 
<div class="Priklad">
Get-WMIObjects -class Win32_bios -ComputerName (Get-ADComputers -Filter *).Name
+
Get-WMIObjects -class Win32_bios -ComputerName (Get-ADComputers -Filter *).Name
 
</div>
 
</div>
  
; Lze kombinovat se závorkou a:
+
; Lze kombinovat se závorkou a&nbsp;<code>-ExpandProperty</code>
-ExpandProperty
+
 
<div class="Priklad">
 
<div class="Priklad">
  Get-WMIObjects -class Win32_bios -ComputerName (Get-ADComputers -Filter *| Select -ExpandProperty name)
+
  Get-WMIObjects -class ''Win32_bios'' -ComputerName (Get-ADComputers -Filter ''*'' | Select -ExpandProperty ''name'')
 
</div>
 
</div>

Verze z 10. 1. 2022, 12:19


Obsah

Princip

Get-Process *ss | Where handles -gt 900 | Sort handles
Get-Service Sym* | Stop-Service -WhatIf


Zpracování

| Get-Member
| Select
Get-ChildItem | Select -Property Name,Length | Sort -Property Length -Descending
| Sort
| Measure
Get-Verb | Measure

Filtrování

| Where-Object
Get-Service | Where {$_.Status -eq "Running"}
Get-Service | Where Status -eq "Running"
Operátory
Doporučený postup
Pro filtrování je lépe použít parametr -Filter

Místo:

Get-ChildItem | Where Name -like "*.xls"

Můžeme tedy psát:

Get-ChildItem -Filter "*.xls"

Nebo dokonce:

Get_ChildItem *.xls

Výstup do souboru

... | Out-File vystup.txt


Předávání dat

Přijímání vstupu

Get-Process calc | dir
  • Spusť předtím kalkulačku
  • Zobrazí obsah adresáře, ve kterém je program, který realizuje proces Calc.

Předávání počítačů

Lze použít {...}
Get-ADComputers -Filter * | Get-WMIObjects -class Win32_bios -ComputerName {$_.Name}
Mnoho příkazů umí také
Get-WMIObjects -class Win32_bios -ComputerName (Get-ADComputers -Filter *).Name
Lze kombinovat se závorkou a -ExpandProperty
Get-WMIObjects -class Win32_bios -ComputerName (Get-ADComputers -Filter * | Select -ExpandProperty name)
Osobní nástroje
Jmenné prostory
Varianty
Akce
Výuka
Navigace
Nástroje