Powershell: Pipelining

Z MiS
(Rozdíly mezi verzemi)
Přejít na: navigace, hledání
m (Opravy formátu v sekci Filtrování.)
(Filtrování: Opraveno Where-Object)
Řádka 53: Řádka 53:
 
== Filtrování ==
 
== Filtrování ==
 
  | Where-object
 
  | Where-object
| Where
+
* Commandlet pro obecné filtrování.
; Lze využít
+
* Aliasy: <code>Where</code>
# <code>$_</code>
+
 
#* Zastupuje aktuální objekt z kolekce.
+
* <code>-FilterScript {''...''}</code>
#* Můžeme pracovat s&nbsp;vlastnostmi tohoto objektu.
+
** Je default parametr, takže stačí i: <code> {''...''}</code>
# <code>{''...''}</code>
+
** Spustí kód v závorkách.
#* Spustí kód v závorkách.
+
** 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 spuštěný kód vrací pro tento objekt z&nbsp;kolekce <code>$true</code>, ponechá tento objekt v kolekci.
+
 
#* Pokud vrací <code>$false</code>, zahodí tento objekt.
+
* Lze využít: <code>$_</code>
 +
** Zastupuje aktuální objekt z kolekce.
 +
** Můžeme pracovat s&nbsp;vlastnostmi tohoto objektu.
 
<div class="Priklad">
 
<div class="Priklad">
 
  Get-Service | Where {$_.Status -eq "Running"}
 
  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>
 
</div>
  
Řádka 80: Řádka 88:
 
* 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
+
; Pro filtrování je lépe použít parametr <code>-Filter</code>
 +
* Ale ne všechny příkazy ho mají.
 
<div class="Priklad">
 
<div class="Priklad">
  Get-Service | Where Status -eq "Running"
+
  Get-ChildItem -Filter "*.xls"
 +
místo:
 
  Get-ChildItem | Where Name -like "*.xls"
 
  Get-ChildItem | Where Name -like "*.xls"
 
</div>
 
</div>
 
  
 
== Výstup do souboru ==
 
== Výstup do souboru ==

Verze z 16. 1. 2019, 14:46


Obsah

Princip

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


Zpracování

| Get-Methods
| 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
Get-ChildItem -Filter "*.xls"

místo:

Get-ChildItem | Where Name -like "*.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