Powershell: Základy
Z MiS
(Rozdíly mezi verzemi)
(Aliasy přesunuty na tuto stránku ze stránky commandlets.) |
(Přidáno předávání dat jako objekty a Get-Member.) |
||
(Není zobrazeno 9 mezilehlých verzí od 1 uživatele.) | |||
Řádka 17: | Řádka 17: | ||
* Unix je zaměřený na práci se soubory — ovládání systému se řeší zápisem do virtuálních souborů. | * Unix je zaměřený na práci se soubory — ovládání systému se řeší zápisem do virtuálních souborů. | ||
* Windows jsou zaměřené na ovládání skrz API — nejsou zde odpovídající virtuální soubory. | * Windows jsou zaměřené na ovládání skrz API — nejsou zde odpovídající virtuální soubory. | ||
− | * Předávání dat mezi programy neprobíhá formou plain-textu, ale objektů. | + | * Předávání dat mezi programy neprobíhá formou plain-textu, ale objektů viz [[#Předávání výstupu| sekce Předávání výstupu]]. |
Řádka 47: | Řádka 47: | ||
* Metaznaky | * Metaznaky | ||
** <code>*</code>... zastupuje libovolné znaky. | ** <code>*</code>... zastupuje libovolné znaky. | ||
+ | ** Lze použít i v rámci našeptávání:<br /><code>*-LocalUser</code> a tabulátor pak nabízí slovesa viz dále. | ||
* Více příkazů na jednom řádku oddělíme středníkem | * Více příkazů na jednom řádku oddělíme středníkem | ||
* Case-insensitive... Nerozlišují se malá a velká písmena | * Case-insensitive... Nerozlišují se malá a velká písmena | ||
+ | |||
+ | |||
+ | == Předávání výstupu == | ||
+ | * Při přesměrování výstupu příkazu nepředává text (jako klasický příkazový řádek Windows či shell Linuxu), ale předává objekty s atributy. | ||
+ | * Tyto objekty lze převést na text například při výstupu na obrazovku, ale lze s nimi pracovat i jako s objekty. | ||
+ | |||
+ | ''...commandlet...'' | Get-Member | ||
+ | * Alias: <code>gm</code> | ||
+ | * Zjistí, jaké vlastnosti mají objekty, které jsou výsledkem commandletu. | ||
+ | * Pomocí <code>Select</code> pak lze vybrat zobrazení těch vlastností, které nás zajímají. (Dále viz [[Powershell: Pipelining|pipelining]]). | ||
Řádka 60: | Řádka 71: | ||
* Aliasy: gal | * Aliasy: gal | ||
<div class="Priklad"> | <div class="Priklad"> | ||
− | + | Get-Alias md | |
Výstup: | Výstup: | ||
* md → mkdir | * md → mkdir | ||
Řádka 67: | Řádka 78: | ||
* Jaký příkaz zastupuje alias <code>dir</code>? | * Jaký příkaz zastupuje alias <code>dir</code>? | ||
− | <div class="Priklad">Get-Alias -Name dir</div> | + | <div class="Priklad"> |
+ | Get-Alias -Name dir | ||
+ | </div> | ||
Get-Alias -Definition ''Zastoupený-příkaz'' | Get-Alias -Definition ''Zastoupený-příkaz'' | ||
* Jaké aliasy můžeme použít místo zadaného commandletu? | * Jaké aliasy můžeme použít místo zadaného commandletu? | ||
<div class="Priklad"> | <div class="Priklad"> | ||
− | + | Get-Alias -Definition Get-ChildItem | |
+ | |||
Výstup: | Výstup: | ||
− | + | dir → Get-ChildItem | |
− | + | ls → Get-ChildItem | |
</div> | </div> | ||
Řádka 88: | Řádka 102: | ||
== Ovládání Powershellu == | == Ovládání Powershellu == | ||
* <code>''Tabulátor''</code> → doplňování příkazů | * <code>''Tabulátor''</code> → doplňování příkazů | ||
+ | <div class="Poznamka"> | ||
+ | V našeptávači můžete použít metaznaky <code>*</code> a <code>?</code>. Například: | ||
+ | *User | ||
+ | (Bude nabízet commandlety, které mají v názvu <code>User</code>.) | ||
+ | </div> | ||
* <code>#fráze + ''Tabulátor''</code> | * <code>#fráze + ''Tabulátor''</code> | ||
** vyhledává frázi v historii použitých příkazů | ** vyhledává frázi v historii použitých příkazů | ||
* Nastavení prostředí | * Nastavení prostředí | ||
** Pravé tlačítko na ikonku v levé horní části okna. | ** Pravé tlačítko na ikonku v levé horní části okna. | ||
− | |||
== ISE == | == ISE == | ||
− | *Integrated | + | *Integrated Scripting Environment |
*Obdoba IDE pro programovací jazyky. | *Obdoba IDE pro programovací jazyky. | ||
*Má kontextovou nápovědu. | *Má kontextovou nápovědu. | ||
− | == | + | == Verze Powershellu == |
* Powershell se vyvíjí, přibývají nové příkazy a varianty syntaxe. | * Powershell se vyvíjí, přibývají nové příkazy a varianty syntaxe. | ||
− | + | * Díky tomu ale některé návody nemusí vždy fungovat — je třeba ověřit verzi. | |
− | + | * První verze uvolněna v roce 2006. | |
+ | * V roce 2021 ve Windows obvykle verze 5.1. | ||
+ | * Až do verze 5 jako „Windows Powershell“. Verze 6 s názvem „Powershell Core 6.0“ již platformně nezávislá, existuje implementace pro Linux a macOS. | ||
+ | * U verze 7 se předpokládá, že nahradí verze 6 i 5.1. | ||
+ | |||
+ | * Zjištění verze: | ||
+ | $PSversionTable | ||
+ | Get-Host | Select-Object Version | ||
+ | $host.version | ||
+ | |||
+ | == Při problémech a nefunkčních návodech == | ||
* Je složen z modulů, je možné, že nemáte nainstalován odpovídající modul. | * Je složen z modulů, je možné, že nemáte nainstalován odpovídající modul. | ||
* Na Windows Serveru jsou některé moduly, které běžné Windows nemají. | * Na Windows Serveru jsou některé moduly, které běžné Windows nemají. | ||
Řádka 117: | Řádka 145: | ||
*[https://channel9.msdn.com//Series/advpowershell3/08/ Advanced Tools & Scripting with PowerShell] | *[https://channel9.msdn.com//Series/advpowershell3/08/ Advanced Tools & Scripting with PowerShell] | ||
*[http://www.powershell.org Powershell.org] | *[http://www.powershell.org Powershell.org] | ||
+ | * [https://www.itnetwork.cz/windows/powershell/powershell-pro-zacatecniky-lekce-1 ITNetwork.cz → Powershell pro začátečníky (první část kurzu zdarma, další placená)] |
Aktuální verze z 9. 1. 2024, 10:23
Obsah[skrýt] |
Úvod
- Powershell je novější alternativou klasického příkazového řádku Windows.
- Zkratka PS.
- Zdrojový kód uvolněn veřejně. (Přeloženo i pro Linux.)
- Proč je třeba rozvíjet příkazový řádek?
- Snaha o jednotné ovládací rozhraní v CLI.
- S rozvojem cloudových řešení (Microsoft Azure) rostou nároky na automatizaci provozu a vytváření serverů.
- Díky aliasům můžeme použít
- nativní příkazy Windows
- nativní příkazy Unixu (ale parametry už obvykle ne)
- Srovnání s Bashem
- Unix je zaměřený na práci se soubory — ovládání systému se řeší zápisem do virtuálních souborů.
- Windows jsou zaměřené na ovládání skrz API — nejsou zde odpovídající virtuální soubory.
- Předávání dat mezi programy neprobíhá formou plain-textu, ale objektů viz sekce Předávání výstupu.
Pojmy
- Workflow
- Možnost spustit sadu příkazů a zavřít aktivní shell, i když dávka ještě běží.
- Cmdlet (Commandlet)... nativní příkaz Powershellu
Syntaxe
- Názvy commandletů
-
Sloveso+pomlčka+podstatné_jméno
- Podstatné jméno je vždy v jednotném čísle.
-
- Slovesa v názvech commandletů
-
Get-
,Set-
-
Add-
-
Copy-
,Remove-
,Move-
-
Import-
,Export-
,ConvertTo-
-
Start-
,Stop-
- Příklad:
Get-Help
- Výpis všech dostupných sloves:
Get-Verb
-
- Přepínače... začínají pomlčkou
- Parametry přepínačů
- Přepínač může mít více parametrů oddělených čárkou
- Sady přepínačů
- Některé kombinace přepínačů mohou fungovat spolu.
- Jiné přepínače nelze kombinovat.
- Metaznaky
-
*
... zastupuje libovolné znaky. - Lze použít i v rámci našeptávání:
*-LocalUser
a tabulátor pak nabízí slovesa viz dále.
-
- Více příkazů na jednom řádku oddělíme středníkem
- Case-insensitive... Nerozlišují se malá a velká písmena
Předávání výstupu
- Při přesměrování výstupu příkazu nepředává text (jako klasický příkazový řádek Windows či shell Linuxu), ale předává objekty s atributy.
- Tyto objekty lze převést na text například při výstupu na obrazovku, ale lze s nimi pracovat i jako s objekty.
...commandlet... | Get-Member
- Alias:
gm
- Zjistí, jaké vlastnosti mají objekty, které jsou výsledkem commandletu.
- Pomocí
Select
pak lze vybrat zobrazení těch vlastností, které nás zajímají. (Dále viz pipelining).
Aliasy
- Protože jsou názvy commandletů dlouhé, existují k nim zkrácené verze — aliasy.
- Pokud existuje obdobný příkaz Windows nebo Linuxu, obvykle existují i odpovídající aliasy.
Get-Alias alias Get-Alias -Name alias
- Dohledání původního příkazu k zadanému aliasu.
- Aliasy: gal
Get-Alias md
Výstup:
- md → mkdir
- Jaký příkaz zastupuje alias
dir
?
Get-Alias -Name dir
Get-Alias -Definition Zastoupený-příkaz
- Jaké aliasy můžeme použít místo zadaného commandletu?
Get-Alias -Definition Get-ChildItem
Výstup:
dir → Get-ChildItem ls → Get-ChildItem
Doporučení:
- Pro ruční práci používejte zkrácené verze příkazů.
- Skripty pište v plné verzi.
Ovládání Powershellu
-
Tabulátor
→ doplňování příkazů
V našeptávači můžete použít metaznaky *
a ?
. Například:
*User
(Bude nabízet commandlety, které mají v názvu User
.)
-
#fráze + Tabulátor
- vyhledává frázi v historii použitých příkazů
- Nastavení prostředí
- Pravé tlačítko na ikonku v levé horní části okna.
ISE
- Integrated Scripting Environment
- Obdoba IDE pro programovací jazyky.
- Má kontextovou nápovědu.
Verze Powershellu
- Powershell se vyvíjí, přibývají nové příkazy a varianty syntaxe.
- Díky tomu ale některé návody nemusí vždy fungovat — je třeba ověřit verzi.
- První verze uvolněna v roce 2006.
- V roce 2021 ve Windows obvykle verze 5.1.
- Až do verze 5 jako „Windows Powershell“. Verze 6 s názvem „Powershell Core 6.0“ již platformně nezávislá, existuje implementace pro Linux a macOS.
- U verze 7 se předpokládá, že nahradí verze 6 i 5.1.
- Zjištění verze:
$PSversionTable Get-Host | Select-Object Version $host.version
Při problémech a nefunkčních návodech
- Je složen z modulů, je možné, že nemáte nainstalován odpovídající modul.
- Na Windows Serveru jsou některé moduly, které běžné Windows nemají.
Některé commandlety smí použít jen správce!
- Vyzkoušej spuštění PS jako správce!
Zdroje
- Microsoft Virtual Academy: Getting Started with PowerShell
- Advanced Tools & Scripting with PowerShell
- Powershell.org
- ITNetwork.cz → Powershell pro začátečníky (první část kurzu zdarma, další placená)