about_Modules
Krátký popis
Vysvětluje, jak nainstalovat, importovat a používat moduly PowerShellu.
Dlouhý popis
PowerShell je příkazové prostředí i skriptovací jazyk. Příkazy v PowerShellu se implementují jako skripty, funkce nebo rutiny. Jazyk obsahuje klíčová slova, která poskytují strukturu a logiku zpracování a další prostředky, jako jsou proměnné, zprostředkovatelé, aliasy.
Modul je samostatná opakovaně použitelná jednotka, která může zahrnovat rutiny, poskytovatele, funkce, proměnné a další prostředky, které je možné importovat do relace PowerShellu nebo do libovolného vlastního programu PowerShellu.
Než bude možné použít funkce obsažené v modulu, musí se modul načíst do relace PowerShellu. Ve výchozím nastavení PowerShell automaticky načte nainstalovaný modul při prvním použití příkazu z modulu. Pomocí proměnné $PSModuleAutoloadingPreference
můžete nakonfigurovat chování automatického načítání modulů . Další informace najdete v tématu about_Preference_Variables.
Moduly můžete také ručně uvolnit nebo znovu načíst během relace PowerShellu. K uvolnění modulu použijte rutinu Remove-Module
. K načtení nebo opětovnému načtení modulu použijte Import-Module
.
PowerShell se dodává se základní sadou modulů. Každý může vytvářet nové příkazy PowerShellu nebo jiné prostředky a publikovat je jako moduly, které si uživatelé můžou podle potřeby nainstalovat.
Moduly můžete psát v jazyce C# jako kompilovaná sestavení .NET, označovaná jako nativní moduly, nebo v prostém PowerShellu, označovaných jako skriptové moduly. Toto téma vysvětluje, jak používat moduly PowerShellu. Informace o tom, jak vytvořit moduly PowerShellu, najdete v tématu Vytvoření modulu PowerShellu.
Poznámka:
Před PowerShellem 3.0 se rutiny a zprostředkovatelé zabalily do modulů snap-in PowerShellu. Počínaje PowerShellem 3.0 se modul snap-in Microsoft.PowerShell.Core ve výchozím nastavení přidá do každé relace. Toto je jediný modul snap-in, který zbývá v PowerShellu. Všechny ostatní moduly snap-in byly převedeny na moduly. Vytváření nových modulů snap-in se už nepodporuje.
Instalace publikovaného modulu
Publikovaný modul je modul, který je k dispozici v registrovaném úložišti, jako je například Galerie prostředí PowerShell. Moduly PowerShellGet a Microsoft.PowerShell.PSResourceGet poskytují rutiny pro hledání, instalaci a publikování modulů PowerShellu do registrovaného úložiště.
Modul PowerShellGet je součástí PowerShellu 5.0 a novějších verzí. Modul Microsoft.PowerShell.PSResourceGet je součástí PowerShellu 7.4 a novějších verzí. Microsoft.PowerShell.PSResourceGet je nový upřednostňovaný správce balíčků pro PowerShell a dá se nainstalovat v předchozích verzích PowerShellu. Moduly Install-Module
můžete nainstalovat z Galerie prostředí PowerShell pomocí rutinyInstall-PSResource
.
Get-Command Install-Module, Install-PSResource
CommandType Name Version Source
----------- ---- ------- ------
Function Install-Module 2.9.0 PowerShellGet
Cmdlet Install-PSResource 1.0.0 Microsoft.PowerShell.PSResourceGet
Další informace najdete v tématu Přehled modulu PowerShellGet.
Ruční instalace modulu
Pokud modul obdržíte jako složku se soubory, musíte ho nainstalovat do počítače, abyste ho mohli použít v PowerShellu.
PowerShell obsahuje několik předinstalovaných modulů. Na počítačích se systémem Windows obsahuje mnoho funkcí systému Windows moduly pro správu této funkce. Tyto moduly se nainstalují při instalaci funkce. Další moduly můžou být součástí instalačního programu nebo instalačního programu, který modul nainstaluje.
Ve výchozím nastavení Modules
složka pro aktuálního uživatele neexistuje. Pokud jste nainstalovali modul v CurrentUser
oboru pomocí Install-Module
nebo Install-PSResource
, tyto rutiny vytvoří Modules
složku pro aktuálního uživatele. Pokud složka neexistuje, můžete ji vytvořit ručně.
Pomocí následujícího příkazu vytvořte Modules
složku pro aktuálního uživatele:
$folder = New-Item -Type Directory -Path $HOME\Documents\PowerShell\Modules
Zkopírujte celou složku modulu do nové vytvořené složky. V PowerShellu použijte rutinu Copy-Item
. Spusťte například následující příkaz, který zkopíruje MyModule
složku ze C:\PSTest
složky, kterou jste právě vytvořili:
Copy-Item -Path C:\PSTest\MyModule -Destination $folder
Modul můžete nainstalovat do libovolného umístění, ale instalace modulů do výchozího umístění modulu usnadňuje správu. Další informace o výchozích umístěních modulů najdete v tématu about_PSModulePath.
Automatické načítání modulů
Při prvním spuštění příkazu z nainstalovaného modulu PowerShell automaticky importuje (načte) tento modul. Modul musí být uložen v umístěních zadaných $env:PSModulePath
v proměnné prostředí. Moduly v jiných umístěních musí být importovány pomocí rutiny Import-Module
.
Automatické načítání modulů umožňuje používat příkazy v modulu bez jakékoli konfigurace nastavení nebo profilu. Po instalaci modulů do počítače není nutné spravovat moduly.
Každý z následujících příkladů způsobí , že se modul CimCmdlets , který obsahuje Get-CimInstance
, importuje do vaší relace.
Spuštění příkazu
Get-CimInstance Win32_OperatingSystem
Získání příkazu
Get-Command Get-CimInstance
Získání nápovědy k příkazu
Get-Help Get-CimInstance
Pomocí seznamu rutin můžete příkazy ve všech nainstalovaných modulech použít Get-Command
, i když ještě nejsou v relaci. Pokud používáte Get-Command
se zástupným znakem (*
), PowerShell neimportuje žádné moduly. Pro zjišťování příkazů můžete použít zástupné cardy, aniž byste museli načítat moduly, které možná v relaci nepotřebujete.
Příkazy, které používají zprostředkovatele PowerShellu, také automaticky neimportuje modul. Pokud například použijete příkaz, který vyžaduje jednotku WSMan:
, například rutinu Get-PSSessionConfiguration
, budete muset spustit Import-Module
rutinu pro import modulu Microsoft.WSMan.Management , který obsahuje jednotku WSMan:
.
Ruční import modulu
Ruční import modulu se vyžaduje, když se modul nenainstaluje v umístěních určených $env:PSModulePath
proměnnou prostředí nebo když je modul poskytován jako samostatný .dll
nebo .psm1
soubor, a ne zabalený modul.
Můžete také změnit způsob importu modulu ve vaší relaci. Například parametr Prefix pro Import-Module
přidání výrazné předpony do části podstatných jmen rutin importovaných z modulu. Parametr NoClobber brání modulu v přidávání příkazů, které by skrývaly nebo nahradily existující příkazy v relaci. Další informace najdete v tématu Správa konfliktů názvů.
Modul, který je nainstalovaný ve vašem počítači $env:PSModulePath
, můžete importovat zadáním názvu modulu. Například následující příkaz naimportuje modul BitsTransfer do aktuální relace.
Import-Module BitsTransfer
Pokud chcete importovat modul, který není ve vašem $env:PSModulePath
modulu, použijte plně kvalifikovanou cestu ke složce modulu. Pokud například chcete do relace přidat modul TestCmdlets , C:\ps-test
zadejte:
Import-Module C:\ps-test\TestCmdlets
Pokud chcete importovat soubor modulu, který není obsažen ve složce modulu, použijte plně kvalifikovanou cestu k souboru modulu v příkazu. Pokud například chcete do relace přidat modul TestCmdlets.dll v C:\ps-test
adresáři, zadejte:
Import-Module C:\ps-test\TestCmdlets.dll
Další informace o přidávání modulů do relace najdete v tématu Import-Module.
Import modulu na začátku každé relace
Příkaz Import-Module
naimportuje moduly do aktuální relace PowerShellu. Pokud chcete importovat modul do každé spuštěné relace PowerShellu, přidejte tento Import-Module
příkaz do profilu PowerShellu.
Další informace o profilech najdete v tématu about_Profiles.
Vyhledání nainstalovaných modulů
Rutina Get-Module
získá moduly PowerShellu, které byly importovány ve vaší relaci.
Get-Module
Uvedené moduly mohou zahrnovat moduly, které byly importovány z libovolného umístění, nejen z $env:PSModulePath
.
Pomocí následujícího příkazu zobrazte seznam modulů nainstalovaných v nástroji $env:PSModulePath
:
Get-Module -ListAvailable
Tento příkaz získá všechny moduly, které jsou nainstalovány , $env:PSModulePath
nejen moduly importované do aktuální relace. Tento příkaz nevypisuje moduly nainstalované v jiných umístěních.
Další informace najdete v tématu Get-Module.
Výpis příkazů v modulu
Pomocí rutiny Get-Command
vyhledejte všechny dostupné příkazy. Pomocí parametrů Get-Command
rutiny můžete filtrovat příkazy, jako je modul, název a podstatné jméno.
Pokud chcete najít všechny příkazy v modulu, zadejte:
Get-Command -Module <module-name>
Pokud chcete například najít příkazy v modulu BitsTransfer , zadejte:
Get-Command -Module BitsTransfer
Další informace o rutině Get-Command
najdete v tématu Get-Command.
Odebrání modulu
Když modul odeberete, příkazy přidaného modulu se z relace odstraní. Například následující příkaz odebere modul BitsTransfer z aktuální relace.
Remove-Module BitsTransfer
Odebrání modulu obrátí operaci importu modulu. Odebráním modulu se modul neodinstaluje. Další informace naleznete v tématu Remove-Module.
Příkazy můžete do relace přidat z modulů a modulů snap-in. Moduly můžou přidávat všechny typy příkazů, včetně rutin, poskytovatelů a funkcí a položek, jako jsou proměnné, aliasy a jednotky PowerShellu. Moduly snap-in můžou přidávat jenom rutiny a poskytovatele.
Před odebráním modulu z relace pomocí následujících příkazů určete, který modul chcete odebrat.
K vyhledání zdroje Get-Date
rutin Get-Help
použijte například následující příkaz:
Get-Command Get-Date, Get-Help -All |
Select-Object -Property Name, CommandType, Module ,PSSnapIn
Následující výstup ukazuje, že rutina Get-Help
je v modulu snap-in Microsoft.PowerShell.Core . Tento modul snap-in nelze z relace odebrat.
Name CommandType Module PSSnapIn
---- ----------- ------ --------
Get-Date Function
Get-Date Cmdlet Microsoft.PowerShell.Utility
Get-Help Cmdlet Microsoft.PowerShell.Core
Existují dva zdroje pro Get-Date
. Jedna je funkce a druhá je rutina v modulu Microsoft.PowerShell.Utility . Modul můžete odebrat pomocí Remove-Module
. Pokud chcete funkci odebrat, můžete ji odstranit z Function:
jednotky.
Remove-Item Function:Get-Date
Další informace o jednotce Function:
najdete v tématu about_Function_Provider.
Správa konfliktů názvů
Ke konfliktům názvů dochází v případě, že více příkazů v relaci má stejný název. Import modulu způsobí konflikt názvů, když příkazy v modulu mají stejné názvy jako příkazy nebo položky v relaci.
Import-Module
může přidávat příkazy, které skrývají a nahrazují příkazy v aktuální relaci. Konflikty názvů můžou vést ke skrytí nebo nahrazení příkazů. Nahrazení příkazu nastane, když importovaný modul obsahuje příkaz se stejným názvem jako existující příkaz v relaci. Nově importovaný příkaz nahrazuje přednost před existujícím příkazem.
Pokud například relace obsahuje funkci a rutinu se stejným názvem, PowerShell ve výchozím nastavení spustí funkci. Pokud relace obsahuje příkazy stejného typu se stejným názvem, například dvě rutiny se stejným názvem, ve výchozím nastavení spustí naposledy přidaný příkaz.
Další informace, včetně vysvětlení pravidel priority a pokynů pro spouštění skrytých příkazů, najdete v tématu about_Command_Precedence.
Můžete spustit příkaz, který je skrytý nebo nahrazený opravňujícím názvem příkazu. Pokud chcete kvalifikovat název příkazu, přidejte název modulu, který obsahuje požadovanou verzi příkazu. Příklad:
Microsoft.PowerShell.Utility\Get-Date
Spuštění Get-Date
s předponou názvu modulu zajišťuje, že je spuštěna verze z modulu Microsoft.PowerShell.Utility .
Ke zjištění konfliktů názvů použijte parametr All rutiny Get-Command
. Ve výchozím nastavení se načte pouze příkazy, Get-Command
které se spustí při zadání názvu příkazu. Parametr All získá všechny příkazy s konkrétním názvem v relaci.
Chcete-li zabránit konfliktům názvů, použijte parametry NoClobber nebo Prefix rutiny Import-Module
. Parametr Prefix přidá předponu k názvům importovaných příkazů, aby byly v relaci jedinečné. Parametr NoClobber neimportuje žádné příkazy, které by skrývaly nebo nahradily existující příkazy v relaci.
Pomocí parametrů Alias, Rutina, Funkce a Proměnná můžete také vybrat pouze příkazy, které chcete importovat, a můžete vyloučit příkazy, které způsobují konflikty názvů ve vaší Import-Module
relaci.
Autoři modulů můžou zabránit konfliktům názvů pomocí vlastnosti DefaultCommandPrefix manifestu modulu k přidání výchozí předpony ke všem názvům příkazů. Hodnota parametru Prefix má přednost před hodnotou DefaultCommandPrefix.