Sdílet prostřednictvím


Test-Path

Určuje, zda existují všechny prvky cesty.

Syntaxe

Test-Path
    [-Path] <String[]>
    [-Filter <String>]
    [-Include <String[]>]
    [-Exclude <String[]>]
    [-PathType <TestPathType>]
    [-IsValid]
    [-Credential <PSCredential>]
    [-OlderThan <DateTime>]
    [-NewerThan <DateTime>]
    [<CommonParameters>]
Test-Path
    -LiteralPath <String[]>
    [-Filter <String>]
    [-Include <String[]>]
    [-Exclude <String[]>]
    [-PathType <TestPathType>]
    [-IsValid]
    [-Credential <PSCredential>]
    [-OlderThan <DateTime>]
    [-NewerThan <DateTime>]
    [<CommonParameters>]
Test-Path
    [-Path] <string[]>
    [-Filter <string>]
    [-Include <string[]>]
    [-Exclude <string[]>]
    [-PathType <TestPathType>]
    [-IsValid]
    [-Credential <pscredential>]
    [<CommonParameters>]
Test-Path
    -LiteralPath <string[]>
    [-Filter <string>]
    [-Include <string[]>]
    [-Exclude <string[]>]
    [-PathType <TestPathType>]
    [-IsValid]
    [-Credential <pscredential>]
    [<CommonParameters>]

Description

Rutina Test-Path určuje, jestli existují všechny prvky cesty. Vrátí $true , pokud všechny prvky existují a $false pokud nějaké chybí. Může také zjistit, zda je syntaxe cesty platná a zda cesta vede ke kontejneru, nebo terminálu nebo prvku typu list. Pokud je cesta prázdným nebo prázdným řetězcem, vrátí $falserutina . Pokud je $nullcesta , pole $null nebo prázdné pole, rutina vrátí neukončující chybu.

Příklady

Příklad 1: Testování cesty

Test-Path -Path "C:\Documents and Settings\DavidC"

True

Tento příkaz zkontroluje, jestli existují všechny prvky v cestě, včetně C: adresáře, Documents and Settings adresáře a DavidC adresáře. Pokud nějaké chybí, rutina vrátí $false. V opačném případě se vrátí $true.

Příklad 2: Otestování cesty k profilu

Test-Path -Path $profile

False

Test-Path -Path $profile -IsValid

True

Tyto příkazy otestují cestu k profilu PowerShellu.

První příkaz určuje, zda existují všechny prvky v cestě. Druhý příkaz určuje, zda je syntaxe cesty správná. V tomto případě je $falsecesta , ale syntaxe je správná $true. Tyto příkazy používají $profileautomatickou proměnnou, která odkazuje na umístění profilu, i když profil neexistuje.

Další informace o automatických proměnných najdete v tématu about_Automatic_Variables.

Příklad 3: Zkontrolujte, jestli existují nějaké soubory kromě zadaného typu.

Test-Path -Path "C:\CAD\Commercial Buildings\*" -Exclude *.dwg

False

Tento příkaz zkontroluje, jestli v adresáři Komerční budovy nejsou jiné soubory než .dwg soubory.

Příkaz k určení cesty používá parametr Path . Vzhledem k tomu, že cesta obsahuje mezeru, je cesta uzavřena do uvozovek. Hvězdička na konci cesty označuje obsah adresáře Komerční budova. U dlouhých cest, například této cesty, zadejte několik prvních písmen cesty a pak pomocí klávesy TAB cestu dokončete.

Příkaz určuje parametr Exclude , který určuje soubory, které se mají vynechat z vyhodnocení.

V tomto případě, protože adresář obsahuje pouze .dwg soubory, výsledek je $false.

Příklad 4: Kontrola souboru

Test-Path -Path $profile -PathType leaf

True

Tento příkaz zkontroluje, jestli cesta uložená v $profile proměnné vede k souboru. V tomto případě, protože profil PowerShellu .ps1 je soubor, rutina vrátí $true.

Příklad 5: Kontrola cest v registru

Tyto příkazy se používají Test-Path s poskytovatelem registru PowerShellu.

První příkaz otestuje, jestli je cesta registru klíče registru Microsoft.PowerShellu v systému správná. Pokud je PowerShell správně nainstalovaný, rutina vrátí $true.

Důležité

Test-Path nefunguje správně se všemi poskytovateli PowerShellu. Můžete například použít Test-Path k otestování cesty klíče registru, ale pokud ji použijete k otestování cesty položky registru, vždy se vrátí $false, i když je položka registru přítomna.

Test-Path -Path "HKLM:\Software\Microsoft\PowerShell\1\ShellIds\Microsoft.PowerShell"

True

Test-Path -Path "HKLM:\Software\Microsoft\PowerShell\1\ShellIds\Microsoft.PowerShell\ExecutionPolicy"

False

Příklad 6: Test, jestli je soubor v rozsahu kalendářních dat

Tento příkaz používá dynamické parametry NewerThan a OlderThan k určení, zda pwsh.exe je soubor v počítači novější než July 13, 2009 a starší než minulý týden.

Parametry NewerThan a OlderThan fungují pouze na jednotkách systému souborů.

Get-Command pwsh |
    Select-Object -ExpandProperty Path |
    Test-Path -NewerThan "July 13, 2009" -OlderThan (Get-Date).AddDays(-7)

True

Příklad 7: Testování cesty s hodnotou null

Chyba vrácená pro nullpole null nebo prázdné pole je neukončující chyba. Může být potlačen pomocí .-ErrorAction SilentlyContinue Následující příklad ukazuje všechny případy, které vrací NullPathNotPermitted chybu.

Test-Path $null
Test-Path $null, $null
Test-Path @()

Test-Path : Cannot bind argument to parameter 'Path' because it is null.
At line:1 char:11
+ Test-Path $null
+           ~~~~~
    + CategoryInfo          : InvalidData: (:) [Test-Path], ParameterBindingValidationException
    + FullyQualifiedErrorId : ParameterArgumentValidationErrorNullNotAllowed,Microsoft.PowerShell.Commands.TestPathCommand

Příklad 8: Testování cesty s prázdnými znaky jako hodnotou

Pokud je pro parametr Path zadaný řetězec prázdných znaků, vrátí .$false Jedná se o změnu prostředí Windows PowerShell 5.1. Pokud je zadaný prázdný řetězec, Test-Path vrátí chybu. Následující příklad ukazuje prázdné znaky a prázdný řetězec.

Test-Path ' '
Test-Path ''

False
False

Příklad 9: Testování cesty, která může mít neplatnou jednotku

Při testování cesty, která obsahuje specifikaci jednotky, testování platnosti cesty selže, pokud jednotka neexistuje. Tento problém můžete obejít předponou jednotky názvem zprostředkovatele.

Test-Path -IsValid Z:\abc.txt
Test-Path -IsValid FileSystem::Z:\abc.txt

False
True

Parametry

-Credential

Poznámka:

Tento parametr nejsou podporovány žádnými poskytovateli nainstalovanými v PowerShellu. Pokud chcete zosobnit jiného uživatele nebo zvýšit úroveň přihlašovacích údajů při spuštění této rutiny, použijte Invoke-Command.

Typ:PSCredential
Position:Named
Default value:None
Vyžadováno:False
Přijmout vstup kanálu:True
Přijmout zástupné znaky:False

-Exclude

Určuje položky, které tato rutina vynechá. Hodnota tohoto parametru kvalifikuje parametr Path . Zadejte element nebo vzor cesty, například *.txt. Jsou povoleny zástupné znaky.

Typ:String[]
Position:Named
Default value:None
Vyžadováno:False
Přijmout vstup kanálu:False
Přijmout zástupné znaky:True

-Filter

Určuje filtr ve formátu nebo jazyce poskytovatele. Hodnota tohoto parametru kvalifikuje parametr Path . Syntaxe filtru, včetně použití zástupných znaků, závisí na poskytovateli. Filtry jsou efektivnější než jiné parametry, protože je poskytovatel použije, když načte objekty místo toho, aby objekty po načtení vyfiltroval PowerShell.

Typ:String
Position:Named
Default value:None
Vyžadováno:False
Přijmout vstup kanálu:False
Přijmout zástupné znaky:True

-Include

Určuje cesty, které tato rutina testuje. Hodnota tohoto parametru kvalifikuje parametr Path . Zadejte element nebo vzor cesty, například *.txt. Jsou povoleny zástupné znaky.

Typ:String[]
Position:Named
Default value:None
Vyžadováno:False
Přijmout vstup kanálu:False
Přijmout zástupné znaky:True

-IsValid

Označuje, že tato rutina testuje syntaxi cesty bez ohledu na to, jestli existují prvky cesty. Tato rutina vrátí $true , pokud je syntaxe cesty platná a $false pokud ne. Pokud testovaná cesta obsahuje specifikaci jednotky, rutina vrátí hodnotu false, pokud jednotka neexistuje. PowerShell vrátí hodnotu false, protože neví, který zprostředkovatele jednotek se má testovat.

Poznámka:

V rozhraních .NET 2.1 byla zavedena změna způsobující chybu v rozhraních PATH API. Tyto metody už nekontrolují neplatné znaky cesty. Tato změna způsobila regresi v PowerShellu , kde kontrola IsValid už neprověřuje neplatné znaky. Regrese bude vyřešena v budoucí verzi. Další informace najdete v tématu Zásadní změny v .NET Core 2.1.

Typ:SwitchParameter
Position:Named
Default value:None
Vyžadováno:False
Přijmout vstup kanálu:False
Přijmout zástupné znaky:False

-LiteralPath

Určuje cestu, která se má testovat. 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 znaky, které by powershell mohl interpretovat jako řídicí sekvence, musíte cestu uzavřít do jednoduchých uvozovek, aby se interpretovaly.

Typ:String[]
Aliasy:PSPath, LP
Position:Named
Default value:None
Vyžadováno:True
Přijmout vstup kanálu:True
Přijmout zástupné znaky:False

-NewerThan

Jedná se o dynamický parametr, který zpřístupnil zprostředkovatel FileSystem .

Zadejte čas jako objekt DateTime .

Před PowerShellem 7.5 se rutina ignoruje:

  • Tento parametr při zadání PathType jako jakékoli jiné hodnoty než Any.
  • Parametr OlderThan při použití s tímto parametrem.
  • Tento parametr, když cesta odkazuje na adresář.

Počínaje PowerShellem 7.5 můžete použít tento parametr s libovolnou hodnotou parametru PathType , otestovat rozsah dat pomocí parametru OlderThan a otestovat věk adresářů.

Další informace najdete v tématu about_FileSystem_Provider.

Typ:Nullable<T>[[DateTime]]
Position:Named
Default value:None
Vyžadováno:False
Přijmout vstup kanálu:False
Přijmout zástupné znaky:False

-OlderThan

Jedná se o dynamický parametr, který zpřístupnil zprostředkovatel FileSystem .

Zadejte čas jako objekt DateTime .

Před PowerShellem 7.5 se rutina ignoruje:

  • Tento parametr při zadání PathType jako jakékoli jiné hodnoty než Any.
  • Tento parametr při použití s parametrem NewerThan .
  • Tento parametr, když cesta odkazuje na adresář.

Počínaje PowerShellem 7.5 můžete použít tento parametr s libovolnou hodnotou parametru PathType , otestovat rozsah dat pomocí parametru NewerThan a otestovat věk adresářů.

Další informace najdete v tématu about_FileSystem_Provider.

Typ:Nullable<T>[[DateTime]]
Position:Named
Default value:None
Vyžadováno:False
Přijmout vstup kanálu:False
Přijmout zástupné znaky:False

-Path

Určuje cestu, která se má testovat. Jsou povoleny zástupné znaky. Pokud cesta obsahuje mezery, uzavřete ji do uvozovek.

Typ:String[]
Position:0
Default value:None
Vyžadováno:True
Přijmout vstup kanálu:True
Přijmout zástupné znaky:True

-PathType

Určuje typ konečného prvku v cestě. Tato rutina vrátí $true , pokud je prvek zadaného typu a $false pokud ne. Tento parametr přijímá tyto hodnoty:

  • Container – Prvek, který obsahuje další prvky, například adresář nebo klíč registru.
  • Leaf – Prvek, který neobsahuje jiné prvky, například soubor.
  • Any - Buď kontejner, nebo list.

Určuje, zda poslední prvek v cestě je určitého typu.

Upozornění

Až PowerShell verze 6.1.2, když jsou přepínače IsValid a PathType zadány společně, Test-Path rutina ignoruje přepínač PathType a ověří pouze syntaktickou cestu bez ověření typu cesty.

V závislosti na problému č. 8607 může být oprava tohoto chování zásadní změnou v budoucí verzi, kdy přepínače IsValid a PathType patří do samostatných sad parametrů, a proto není možné toto zmatení použít společně.

Typ:TestPathType
Aliasy:Type
Přípustné hodnoty:Any, Container, Leaf
Position:Named
Default value:None
Vyžadováno:False
Přijmout vstup kanálu:False
Přijmout zástupné znaky:False

Vstupy

String

Řetězec, který obsahuje cestu, ale ne literálovou cestu, můžete do této rutiny převést.

Výstupy

Boolean

Rutina vrátí logickou hodnotu.

Poznámky

Rutiny, které obsahují podstatné jméno cesty ( rutiny Path ), pracují s cestou a vracejí názvy ve stručné podobě, které můžou interpretovat všichni poskytovatelé PowerShellu. Jsou určené pro použití v programech a skriptech, ve kterých chcete zobrazit celou cestu nebo její část v určitém formátu. Použijte je stejně, jako byste použili Dirname, Normpath, Realpath, Join nebo jiné manipulátory cest.

Tato Test-Path funkce je navržená tak, aby fungovala s daty vystavenými jakýmkoli poskytovatelem. Pokud chcete zobrazit seznam poskytovatelů dostupných v relaci, zadejte Get-PSProvider. Další informace najdete v tématu about_Providers.