Add-Type
Přidá třídu Microsoft .NET do relace PowerShellu.
Syntaxe
Add-Type
[-TypeDefinition] <String>
[-Language <Language>]
[-ReferencedAssemblies <String[]>]
[-OutputAssembly <String>]
[-OutputType <OutputAssemblyType>]
[-PassThru]
[-IgnoreWarnings]
[-CompilerOptions <String[]>]
[<CommonParameters>]
Add-Type
[-Name] <String>
[-MemberDefinition] <String[]>
[-Namespace <String>]
[-UsingNamespace <String[]>]
[-Language <Language>]
[-ReferencedAssemblies <String[]>]
[-OutputAssembly <String>]
[-OutputType <OutputAssemblyType>]
[-PassThru]
[-IgnoreWarnings]
[-CompilerOptions <String[]>]
[<CommonParameters>]
Add-Type
[-Path] <String[]>
[-ReferencedAssemblies <String[]>]
[-OutputAssembly <String>]
[-OutputType <OutputAssemblyType>]
[-PassThru]
[-IgnoreWarnings]
[-CompilerOptions <String[]>]
[<CommonParameters>]
Add-Type
-LiteralPath <String[]>
[-ReferencedAssemblies <String[]>]
[-OutputAssembly <String>]
[-OutputType <OutputAssemblyType>]
[-PassThru]
[-IgnoreWarnings]
[-CompilerOptions <String[]>]
[<CommonParameters>]
Add-Type
-AssemblyName <String[]>
[-PassThru]
[<CommonParameters>]
Description
Rutina Add-Type
umožňuje definovat třídu Microsoft .NET Core v relaci PowerShellu. Pak můžete pomocí rutiny New-Object
vytvořit instanci objektů a používat objekty stejně, jako byste použili jakýkoli objekt .NET Core. Pokud do profilu PowerShellu Add-Type
přidáte příkaz, třída je k dispozici ve všech relacích PowerShellu.
Typ můžete zadat zadáním existujícího sestavení nebo souborů zdrojového kódu nebo můžete zadat zdrojový kód vložený nebo uložený v proměnné. Můžete dokonce zadat pouze metodu a Add-Type
definuje a generuje třídu. Ve Windows můžete pomocí této funkce v PowerShellu volat volání nespravovaných funkcí (P/Invoke). Pokud zadáte zdrojový kód, Add-Type
zkompiluje zadaný zdrojový kód a vygeneruje sestavení v paměti, které obsahuje nové typy .NET Core.
Parametry můžete použít Add-Type
k určení alternativního jazyka a kompilátoru, jazyk C# je výchozí, možnosti kompilátoru, závislosti sestavení, obor názvů třídy, názvy typu a výsledné sestavení.
Počínaje PowerShellem 7 nekompiluje typ, Add-Type
pokud již existuje typ se stejným názvem. Add-Type
Také hledá sestavení ve složce pod složkouref
, která obsahuje pwsh.dll
.
Příklady
Příklad 1: Přidání typu .NET do relace
Tento příklad přidá BasicTest třídy do relace zadáním zdrojového kódu, který je uložen v proměnné. BasicTest třída slouží k přidání celých čísel, vytvoření objektu a násobení celých čísel.
$Source = @"
public class BasicTest
{
public static int Add(int a, int b)
{
return (a + b);
}
public int Multiply(int a, int b)
{
return (a * b);
}
}
"@
Add-Type -TypeDefinition $Source
[BasicTest]::Add(4, 3)
$BasicTestObject = New-Object BasicTest
$BasicTestObject.Multiply(5, 2)
Proměnná $Source
ukládá zdrojový kód pro třídu. Typ má volanou Add
statickou metodu a nestatická metoda s názvem Multiply
.
Rutina Add-Type
přidá třídu do relace. Protože používá vložený zdrojový kód, příkaz použije parametr TypeDefinition k určení kódu v $Source
proměnné.
Add
Statická metoda Třídy BasicTest používá dvojité dvojtečky znaků (::
) k určení statického členu třídy. Přičtou se celá čísla a zobrazí se součet.
Rutina New-Object
vytvoří instanci třídy BasicTest . Uloží nový objekt do $BasicTestObject
proměnné.
$BasicTestObject
používá metodu Multiply
. Celá čísla se vynásobí a zobrazí se součin.
Příklad 2: Prozkoumání přidaného typu
Tento příklad používá rutinu Get-Member
k prozkoumání objektů vytvořených Add-Type
New-Object
v příkladu 1.
[BasicTest] | Get-Member
TypeName: System.RuntimeType
Name MemberType Definition
---- ---------- ----------
AsType Method type AsType()
Clone Method System.Object Clone(), System.Object ICloneable.Clone()
Equals Method bool Equals(System.Object obj), bool Equals(type o)
FindInterfaces Method type[] FindInterfaces(System.Reflection.TypeFilter filter...
...
[BasicTest] | Get-Member -Static
TypeName: BasicTest
Name MemberType Definition
---- ---------- ----------
Add Method static int Add(int a, int b)
Equals Method static bool Equals(System.Object objA, System.Object objB)
new Method BasicTest new()
ReferenceEquals Method static bool ReferenceEquals(System.Object objA, System.Object objB)
$BasicTestObject | Get-Member
TypeName: BasicTest
Name MemberType Definition
---- ---------- ----------
Equals Method bool Equals(System.Object obj)
GetHashCode Method int GetHashCode()
GetType Method type GetType()
Multiply Method int Multiply(int a, int b)
ToString Method string ToString()
Rutina Get-Member
získá typ a členy třídy BasicTest , která byla Add-Type
přidána do relace. Příkaz Get-Member
zjistí, že se jedná o objekt System.RuntimeType , který je odvozen z Třídy System.Object .
Get-Member
Statický parametr získá statické vlastnosti a metody BasicTest třídy. Výstup ukazuje, že Add
metoda je zahrnuta.
Rutina Get-Member
získá členy objektu uloženého $BasicTestObject
v proměnné.
$BasicTestObject
byl vytvořen pomocí rutiny New-Object
s BasicTest třídy. Výstup ukazuje, že hodnota $BasicTestObject
proměnné je instance BasicTest třídy a že obsahuje člen volaný Multiply
.
Příklad 3: Přidání typů ze sestavení
Tento příklad přidá třídy ze JsonSchema.NET.dll
sestavení do aktuální relace.
Set-Location -Path $PSHOME
$AccType = Add-Type -AssemblyName *jsonschema* -PassThru
Set-Location
pomocí parametru Path určuje proměnnou $PSHOME
. Proměnná odkazuje na instalační adresář PowerShellu, kde se nachází soubor DLL.
Proměnná $AccType
ukládá objekt vytvořený pomocí rutiny Add-Type
. Add-Type
používá parametr AssemblyName k určení názvu sestavení. Zástupný znak hvězdičky (*
) umožňuje získat správné sestavení, i když si nejste jisti názvem nebo jeho pravopisem. Parametr PassThru generuje objekty, které představují třídy přidané do relace.
Příklad 4: Volání nativních rozhraní API systému Windows
Tento příklad ukazuje, jak volat nativní rozhraní API systému Windows v PowerShellu. Add-Type
používá mechanismus Volání platformy (P/Invoke) k volání funkce z User32.dll
PowerShellu. Tento příklad funguje jenom na počítačích s operačním systémem Windows.
$Signature = @"
[DllImport("user32.dll")]public static extern bool ShowWindowAsync(IntPtr hWnd, int nCmdShow);
"@
$addTypeSplat = @{
MemberDefinition = $Signature
Name = "Win32ShowWindowAsync"
Namespace = 'Win32Functions'
PassThru = $true
}
$ShowWindowAsync = Add-Type @addTypeSplat
# Minimize the PowerShell console
$ShowWindowAsync::ShowWindowAsync((Get-Process -Id $pid).MainWindowHandle, 2)
# Restore the PowerShell console
$ShowWindowAsync::ShowWindowAsync((Get-Process -Id $Pid).MainWindowHandle, 4)
Proměnná $Signature
ukládá podpis ShowWindowAsync
funkce v jazyce C#. Aby se zajistilo, že výsledná metoda je viditelná v relaci PowerShellu, public
bylo klíčové slovo přidáno do standardního podpisu. Další informace naleznete v tématu ShowWindowAsync funkce.
Proměnná $ShowWindowAsync
ukládá objekt vytvořený parametrem Add-Type
PassThru .
Rutina Add-Type
přidá ShowWindowAsync
funkci do relace PowerShellu jako statickou metodu. Příkaz používá Parametr MemberDefinition k určení definice metody uložené v $Signature
proměnné. Příkaz používá parametry Name a Namespace k určení názvu a oboru názvů pro třídu. Parametr PassThru generuje objekt, který představuje typy.
Nová ShowWindowAsync
statická metoda se používá v příkazech k minimalizaci a obnovení konzoly PowerShellu. Metoda má dva parametry: popisovač okna a celé číslo, které určuje způsob zobrazení okna.
Pokud chcete minimalizovat konzolu PowerShellu, ShowWindowAsync
použije rutinu Get-Process
$PID
s automatickou proměnnou k získání procesu hostujícího aktuální relaci PowerShellu. Pak používá MainWindowHandle vlastnost aktuální proces a hodnotu 2
, která představuje SW_MINIMIZE
hodnotu.
Chcete-li okno obnovit, ShowWindowAsync
použije hodnotu 4
pozice okna, která představuje SW_RESTORE
hodnotu.
Chcete-li maximalizovat okno, použijte hodnotu 3
, která představuje SW_MAXIMIZE
.
Parametry
-AssemblyName
Určuje název sestavení, které obsahuje typy. Add-Type
přebírá typy ze zadaného sestavení. Tento parametr se vyžaduje při vytváření typů na základě názvu sestavení.
Zadejte úplný nebo jednoduchý název sestavení, označovaný také jako částečný název sestavení. V názvu sestavení jsou povoleny zástupné znaky. Pokud zadáte jednoduchý nebo částečný název, Add-Type
přeloží ho na úplný název a pak použije úplný název k načtení sestavení.
Použití parametrů Path nebo LiteralPath zaručuje, že načítáte sestavení, které jste chtěli načíst. Pokud použijete parametr AssemblyName , PowerShell požádá .NET, aby přeložil název sestavení pomocí standardního procesu překladu sestavení .NET. Vzhledem k tomu, že .NET nejprve prohledá složku aplikace, Add-Type
může místo verze v aktuální složce načíst sestavení $PSHOME
. Další informace naleznete v tématu Umístění sestavení.
Pokud se rozhraní .NET nepodaří přeložit název, PowerShell vyhledá sestavení v aktuálním umístění. Při použití zástupných znaků v parametru AssemblyName se proces překladu sestavení .NET nezdaří, což způsobí, že PowerShell bude hledat v aktuálním umístění.
Typ: | String[] |
Aliasy: | AN |
Position: | Named |
Default value: | None |
Vyžadováno: | True |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | True |
-CompilerOptions
Určuje možnosti kompilátoru zdrojového kódu. Tyto možnosti se odešlou kompilátoru bez revize.
Tento parametr umožňuje nasměrovat kompilátor tak, aby vygeneroval spustitelný soubor, prostředky pro vložení nebo nastavil možnosti příkazového řádku, jako je tato /unsafe
možnost.
Typ: | String[] |
Position: | Named |
Default value: | None |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-IgnoreWarnings
Ignoruje upozornění kompilátoru. Tento parametr použijte, pokud chcete zabránit Add-Type
zpracování upozornění kompilátoru jako chyb.
Typ: | SwitchParameter |
Position: | Named |
Default value: | False |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-Language
Určuje jazyk, který se používá ve zdrojovém kódu. Přijatelná hodnota pro tento parametr je CSharp
.
Typ: | Language |
Přípustné hodnoty: | CSharp |
Position: | Named |
Default value: | CSharp |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-LiteralPath
Určuje cestu k souborům zdrojového kódu nebo souborům DLL sestavení, které obsahují typy. Na rozdíl od cesty se hodnota parametru LiteralPath používá přesně tak, jak je zadána. Žádné znaky nejsou interpretovány jako zástupné znaky. Pokud cesta obsahuje řídicí znaky, uzavřete ji do jednoduchých uvozovek. Jednoduché uvozovky říkají PowerShellu, aby nepřekládaly žádné znaky jako řídicí sekvence.
Použití parametrů Path nebo LiteralPath zaručuje, že načítáte sestavení, které jste chtěli načíst.
Typ: | String[] |
Aliasy: | PSPath, LP |
Position: | Named |
Default value: | None |
Vyžadováno: | True |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-MemberDefinition
Určuje nové vlastnosti nebo metody pro třídu. Add-Type
vygeneruje kód šablony, který je nutný k podpoře vlastností nebo metod.
Ve Windows můžete pomocí této funkce v PowerShellu volat volání nespravovaných funkcí (P/Invoke).
Typ: | String[] |
Position: | 1 |
Default value: | None |
Vyžadováno: | True |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-Name
Určuje název třídy, která se má vytvořit. Tento parametr se vyžaduje při generování typu z definice člena.
Název typu a obor názvů musí být v rámci relace jedinečný. Typ nelze uvolnit ani ho změnit. Pokud chcete změnit kód pro typ, musíte změnit název nebo spustit novou relaci PowerShellu. Jinak příkaz selže.
Typ: | String |
Position: | 0 |
Default value: | None |
Vyžadováno: | True |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-Namespace
Určuje obor názvů pro typ.
Pokud tento parametr není součástí příkazu, typ se vytvoří v oboru názvů Microsoft.PowerShell.Commands.AddType.AutoGeneratedTypes . Pokud je parametr součástí příkazu s prázdnou řetězcovou hodnotou nebo hodnotou $Null
, typ se vygeneruje v globálním oboru názvů.
Typ: | String |
Aliasy: | NS |
Position: | Named |
Default value: | None |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-OutputAssembly
Vygeneruje soubor KNIHOVNY DLL pro sestavení se zadaným názvem v umístění. Zadejte volitelnou cestu a název souboru. Jsou povoleny zástupné znaky. Ve výchozím nastavení Add-Type
generuje sestavení pouze v paměti.
Typ: | String |
Aliasy: | OA |
Position: | Named |
Default value: | None |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | True |
-OutputType
Určuje výstupní typ výstupního sestavení. Ve výchozím nastavení není zadán žádný typ výstupu. Tento parametr je platný pouze v případě, že je v příkazu zadáno výstupní sestavení. Další informace o hodnotách naleznete v tématu OutputAssemblyType – výčet.
Přijatelné hodnoty pro tento parametr jsou následující:
ConsoleApplication
Library
WindowsApplication
Důležité
Od PowerShellu 7.1 a WindowsApplication
nejsou podporované a PowerShell vyvolá ukončovací chybu, ConsoleApplication
pokud jsou některé z těchto hodnot zadány jako hodnoty pro parametr OutputType.
Typ: | OutputAssemblyType |
Aliasy: | OT |
Přípustné hodnoty: | ConsoleApplication, Library, WindowsApplication |
Position: | Named |
Default value: | None |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-PassThru
Vrátí objekt System.Runtime, který představuje přidané typy. Ve výchozím nastavení tato rutina negeneruje žádný výstup.
Typ: | SwitchParameter |
Position: | Named |
Default value: | False |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-Path
Určuje cestu k souborům zdrojového kódu nebo souborům DLL sestavení, které obsahují typy.
Pokud odesíláte soubory zdrojového kódu, Add-Type
zkompiluje kód v souborech a vytvoří sestavení typů v paměti. Přípona souboru zadaná v hodnotě Path určuje kompilátor, který Add-Type
používá.
Použití parametrů Path nebo LiteralPath zaručuje, že načítáte sestavení, které jste chtěli načíst.
Typ: | String[] |
Position: | 0 |
Default value: | None |
Vyžadováno: | True |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-ReferencedAssemblies
Určuje sestavení, na kterých typ závisí. Ve výchozím nastavení Add-Type
odkazy System.dll
a System.Management.Automation.dll
. Sestavení, která zadáte pomocí tohoto parametru, se kromě výchozích sestavení odkazují.
Počínaje PowerShellem 6 neobsahuje referencedAssemblies výchozí sestavení .NET. Do hodnoty předané tomuto parametru musíte zahrnout konkrétní odkaz.
Typ: | String[] |
Aliasy: | RA |
Position: | Named |
Default value: | None |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-TypeDefinition
Určuje zdrojový kód, který obsahuje definice typu. Zadejte zdrojový kód do řetězce nebo řetězce sem nebo zadejte proměnnou, která obsahuje zdrojový kód. Další informace o tomto řetězci najdete v tématu about_Quoting_Rules.
Do definice typu zahrňte deklaraci oboru názvů. Pokud deklaraci oboru názvů vynecháte, může mít váš typ stejný název jako jiný typ nebo zástupce jiného typu, což způsobí neúmyslné přepsání. Pokud například definujete typ s názvem Výjimka, skripty, které jako zástupce pro System.Exception používají výjimku, selžou.
Typ: | String |
Position: | 0 |
Default value: | None |
Vyžadováno: | True |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-UsingNamespace
Určuje další obory názvů, které jsou požadovány pro třídu. To se podobá klíčovému slovu jazyka C#. Using
Ve výchozím nastavení Add-Type
odkazuje na systémový obor názvů. Pokud se použije parametr MemberDefinition, Add-Type
odkazuje ve výchozím nastavení také na obor názvů System.Runtime.InteropServices. Obory názvů, které přidáte pomocí parametru UsingNamespace , se kromě výchozích oborů názvů odkazují.
Typ: | String[] |
Aliasy: | Using |
Position: | Named |
Default value: | System namespace |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
Vstupy
None
Do této rutiny nemůžete roušit objekty.
Výstupy
None
Ve výchozím nastavení tato rutina nevrací žádný výstup.
Pokud použijete parametr PassThru , tato rutina vrátí objekt System.Type představující nový typ.
Poznámky
Typy, které přidáte, existují pouze v aktuální relaci. Pokud chcete použít typy ve všech relacích, přidejte je do profilu PowerShellu. Další informace o profilu najdete v tématu about_Profiles.
Názvy typů a obory názvů musí být v rámci relace jedinečné. Typ nelze uvolnit ani ho změnit. Pokud potřebujete změnit kód pro typ, musíte změnit název nebo spustit novou relaci PowerShellu. Jinak příkaz selže.
Ve Windows PowerShellu (verze 5.1 a novější) musíte použít Add-Type
cokoli, co ještě není načtené. Nejčastěji se to týká sestavení nalezených v globální mezipaměti sestavení (GAC).
V PowerShellu 6 a novějším není k dispozici žádný GAC, takže PowerShell nainstaluje vlastní sestavení do $PSHOME
.
Tato sestavení se automaticky načtou na žádost, takže není nutné je načíst Add-Type
. Použití Add-Type
je ale nadále povoleno, aby skripty byly implicitně kompatibilní s libovolnou verzí PowerShellu.
Sestavení v GAC lze načíst podle názvu typu, nikoli podle cesty. Načítání sestavení z libovolné cesty vyžaduje Add-Type
, protože tato sestavení nelze načíst automaticky.