Sdílet prostřednictvím


Test-Path

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

Syntax

Path (Výchozí)

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

LiteralPath

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

Description

Cmdlet Test-Path určuje, jestli existují všechny elementy cesty. Vrátí $True, pokud existují všechny prvky a pokud nějaké chybí, $False. Může také zjistit, zda je syntaxe cesty platná a zda cesta vede ke kontejneru, nebo terminálu nebo prvku typu list. Pokud je Path prázdné místo nebo prázdný řetězec, pak $False je vrácen. Pokud je $nullPath , pole nebo $null prázdné pole, vrátí se neukončující chyba.

Příklady

Příklad 1: Testování cesty

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

Tento příkaz zkontroluje, zda existují všechny elementy v cestě, tj. C: adresář Documents and Settings , adresář a DavidC adresář. Pokud nějaké chybí, příkaz vrátí $False. V opačném případě 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 cesta $False, ale syntaxe je správná $True. Tyto příkazy používají $profile, automatickou 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 zadání cesty používá parametr Path. Protože cesta obsahuje mezeru, je 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 k určení souborů, které budou z vyhodnocení vynechány.

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 proměnné $profile vede k souboru. V tomto případě, protože profil PowerShellu je .ps1 soubor, rutina vrátí $True.

Příklad 5: Kontrola cest v registru

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

První příkaz testuje, zda je cesta k klíči registru Microsoft.PowerShell na 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 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 novější než zadané datum

Tento příkaz používá NewerThan dynamický parametr k určení, zda "PowerShell.exe" soubor v počítači je novější než "13. července 2009".

Parametr NewerThan funguje pouze na jednotkách systému souborů.

Test-Path $pshome\pwsh.exe -NewerThan "July 13, 2009"
True

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

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

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 zadán prázdný řetězec , vrátí hodnotu 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 mezery a prázdný řetězec.

Test-Path ' '
Test-Path ''
False
False

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 oprávnění při spuštění této rutiny, použijte Invoke-Command.

Vlastnosti parametru

Typ:PSCredential
Default value:None
Podporuje zástupné znaky:False
DontShow:False

Sady parametrů

(All)
Position:Named
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:True
Hodnota ze zbývajících argumentů:False

-Exclude

Určuje položky, které tento cmdlet opomene. Hodnota tohoto parametru kvalifikuje parametr Path. Zadejte prvek cesty nebo vzor, například "*.txt". Jsou povoleny zástupné znaky.

Vlastnosti parametru

Typ:

String[]

Default value:None
Podporuje zástupné znaky:True
DontShow:False

Sady parametrů

(All)
Position:Named
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

-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 při načítání objektů místo toho, aby objekty po načtení vyfiltroval PowerShell.

Vlastnosti parametru

Typ:String
Default value:None
Podporuje zástupné znaky:True
DontShow:False

Sady parametrů

(All)
Position:Named
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

-Include

Určí cesty, které tento cmdlet testuje. Hodnota tohoto parametru kvalifikuje parametr Path. Zadejte prvek cesty nebo vzor, například "*.txt". Jsou povoleny zástupné znaky.

Vlastnosti parametru

Typ:

String[]

Default value:None
Podporuje zástupné znaky:True
DontShow:False

Sady parametrů

(All)
Position:Named
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

-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 není.

Vlastnosti parametru

Typ:SwitchParameter
Default value:None
Podporuje zástupné znaky:False
DontShow:False

Sady parametrů

(All)
Position:Named
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

-LiteralPath

Určuje cestu, která se má testovat. Na rozdíl od Pathse hodnota parametru LiteralPath používá přesně tak, jak je zadán. Žá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 neinterpretovaly.

Vlastnosti parametru

Typ:

String[]

Default value:None
Podporuje zástupné znaky:False
DontShow:False
Aliasy:PSPath, PO

Sady parametrů

LiteralPath
Position:Named
Povinné:True
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:True
Hodnota ze zbývajících argumentů:False

-NewerThan

Zadejte čas jako objekt DateTime.

Vlastnosti parametru

Typ:

Nullable<T>[DateTime]

Default value:None
Podporuje zástupné znaky:False
DontShow:False

Sady parametrů

(All)
Position:Named
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

-OlderThan

Zadejte čas jako objekt DateTime.

Vlastnosti parametru

Typ:

Nullable<T>[DateTime]

Default value:None
Podporuje zástupné znaky:False
DontShow:False

Sady parametrů

(All)
Position:Named
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

-Path

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

Vlastnosti parametru

Typ:

String[]

Default value:None
Podporuje zástupné znaky:True
DontShow:False

Sady parametrů

Path
Position:0
Povinné:True
Hodnota z kanálu:True
Hodnota z kanálu podle názvu vlastnosti:True
Hodnota ze zbývajících argumentů:False

-PathType

Určuje typ konečného prvku v cestě. Tato rutina vrátí $True, pokud je prvek zadaného typu a $False, pokud není. Přijatelné hodnoty pro tento parametr jsou:

  • Kontejner. Prvek, který obsahuje další prvky, například adresář nebo klíč registru.
  • List. Prvek, který neobsahuje jiné prvky, například soubor.
  • Jakýkoliv. Buď kontejner, nebo list.

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

Upozornění

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

Podle problém č. 8607, oprava tohoto chování může být zásadní změnou v budoucí verzi, kde IsValid a PathType přepínače patří do samostatných sad parametrů, a proto se nelze použít společně.

Vlastnosti parametru

Typ:TestPathType
Default value:None
Přípustné hodnoty:Any, Container, Leaf
Podporuje zástupné znaky:False
DontShow:False
Aliasy:Typ

Sady parametrů

(All)
Position:Named
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

CommonParameters

Tato rutina podporuje běžné parametry: -Debug, -ErrorAction, -ErrorVariable, -InformationAction, -InformationVariable, -OutBuffer, -OutVariable, -PipelineVariable, -ProgressAction, -Verbose, -WarningAction a -WarningVariable. Další informace najdete v about_CommonParameters.

Vstupy

String

Můžete předat řetězec, který obsahuje cestu, ale ne doslovnou cestu, do tohoto příkazu.

Výstupy

Boolean

Cmdlet vrátí logickou hodnotu.

Poznámky

Rutiny, které obsahují Cestu podstatné jméno (rutiny Cesta), pracují s názvy cest 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 název cesty v určitém formátu nebo jeho část. Použijte je stejně, jako byste použili Dirname, normpath, realpath, Joinnebo jiné manipulátory cest.

Test-Path je navržená tak, aby fungovala s daty vystavenými jakýmkoli poskytovatelem. Chcete-li zobrazit seznam poskytovatelů dostupných ve vaší relaci, napište Get-PSProvider. Pro více informací viz about_Providers.