Resolve-Path
Vyřeší zástupné znaky v cestě a zobrazí obsah cesty.
Syntaxe
Resolve-Path
[-Path] <string[]>
[-Relative]
[-RelativeBasePath <string>]
[-Credential <pscredential>]
[-Force]
[<CommonParameters>]
Resolve-Path
-LiteralPath <string[]>
[-Relative]
[-RelativeBasePath <string>]
[-Credential <pscredential>]
[-Force]
[<CommonParameters>]
Description
Rutina Resolve-Path
zobrazí položky a kontejnery, které odpovídají vzoru zástupných znaků v zadaném umístění. Shoda může zahrnovat soubory, složky, klíče registru nebo jakýkoli jiný objekt přístupný od poskytovatele PSDrivu .
Příklady
Příklad 1: Řešení cesty k domovské složce
Znak vlnovky (~
) je zkratka pro domovskou složku aktuálního uživatele. Tento příklad ukazuje Resolve-Path
vrácení plně kvalifikované hodnoty cesty.
Resolve-Path ~
Path
----
C:\Users\User01
Příklad 2: Řešení cesty ke složce Windows
Resolve-Path -Path "windows"
Path
----
C:\Windows
Při spuštění z kořenového C:
adresáře jednotky tento příkaz vrátí cestu Windows
ke složce na C:
jednotce.
Příklad 3: Získání všech cest ve složce Windows
"C:\windows\*" | Resolve-Path
Tento příkaz vrátí všechny soubory a složky ve C:\Windows
složce. Příkaz používá operátor kanálu (|
) k odeslání řetězce cesty do Resolve-Path
.
Příklad 4: Řešení cesty UNC
Resolve-Path -Path "\\Server01\public"
Tento příkaz vyřeší cestu UNC (Universal Naming Convention) a vrátí sdílené složky v cestě.
Příklad 5: Získání relativních cest
Resolve-Path -Path "c:\prog*" -Relative
.\Program Files
.\Program Files (x86)
.\programs.txt
Tento příkaz vrátí relativní cesty pro adresáře v kořenovém adresáři C:
jednotky.
Příklad 6: Řešení cesty obsahující závorky
V tomto příkladu se k překladu cesty Test[xml]
podsložky používá parametr LiteralPath.
Použití literálPath způsobí, že hranaté závorky budou považovány za normální znaky, nikoli jako regulární výraz.
Resolve-Path -LiteralPath 'test[xml]'
Příklad 7: Řešení cesty vzhledem k jiné složce
Tento příklad používá RelativeBasePath parametr k překladu cesty spustitelného pwsh
souboru vzhledem k $env:TEMP
. Pokud příkaz obsahuje parametr Relativní přepínač, vrátí řetězec představující relativní cestu ze $env:TEMP
spustitelného pwsh
souboru.
$ExecutablePath = Get-Command -Name pwsh | Select-Object -ExpandProperty Source
Resolve-Path -Path $ExecutablePath -RelativeBasePath $env:TEMP -Relative
..\..\..\..\..\Program Files\PowerShell\7\pwsh.exe
Příklad 8: Řešení cest pro skryté položky
Ve výchozím nastavení Resolve-Path
nevrací skryté položky. V tomto příkladu se k překladu skrytých položek používá parametr Force . Příkaz Get-Item
potvrdí, že .git
je složka skrytá. Použití Resolve-Path
bez parametru Force vrátí pouze viditelné položky. Přidání parametru Force vrátí všechny položky včetně skrytých položek.
PS> Get-Item .git -Force
Directory: D:\Git\PS-Docs\PowerShell-Docs
Mode LastWriteTime Length Name
---- ------------- ------ ----
d--h- 9/25/2024 4:46 PM .git
PS> Resolve-Path .git*
Path
----
D:\Git\PS-Docs\PowerShell-Docs\.github
D:\Git\PS-Docs\PowerShell-Docs\.gitattributes
D:\Git\PS-Docs\PowerShell-Docs\.gitignore
PS> Resolve-Path .git* -Force
Path
----
D:\Git\PS-Docs\PowerShell-Docs\.git
D:\Git\PS-Docs\PowerShell-Docs\.github
D:\Git\PS-Docs\PowerShell-Docs\.gitattributes
D:\Git\PS-Docs\PowerShell-Docs\.gitignore
Parametry
-Credential
Určuje uživatelský účet, který má oprávnění k provedení této akce. Ve výchozím nastavení je to aktuální uživatel.
Zadejte uživatelské jméno, například User01
nebo Domain01\User01
nebo předejte objekt PSCredential . Objekt PSCredential můžete vytvořit pomocí rutinyGet-Credential
. Pokud zadáte uživatelské jméno, tato rutina vás vyzve k zadání hesla.
Tento parametr nejsou podporovány žádnými poskytovateli nainstalovanými v PowerShellu.
Typ: | PSCredential |
Position: | Named |
Default value: | None |
Vyžadováno: | False |
Přijmout vstup kanálu: | True |
Přijmout zástupné znaky: | False |
-Force
Umožňuje rutině získat položky, ke kterým jinak uživatel nemá přístup, například skryté nebo systémové soubory. Parametr Force nepřepíše omezení zabezpečení. Implementace se liší mezi poskytovateli. Další informace najdete v tématu about_Providers.
Tento parametr byl přidán v PowerShellu 7.5-preview.5.
Typ: | SwitchParameter |
Position: | Named |
Default value: | False |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-LiteralPath
Určuje cestu, která se má přeložit. Hodnota parametru LiteralPath se používá přesně podle typu. Žá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.
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 |
-Path
Určuje cestu PowerShellu, která se má přeložit. Tento parametr je povinný. Řetězec cesty můžete také převést na Resolve-Path
. Jsou povoleny zástupné znaky.
Typ: | String[] |
Position: | 0 |
Default value: | None |
Vyžadováno: | True |
Přijmout vstup kanálu: | True |
Přijmout zástupné znaky: | True |
-Relative
Označuje, že tato rutina vrací relativní cestu.
Typ: | SwitchParameter |
Position: | Named |
Default value: | False |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-RelativeBasePath
Určuje cestu, ze které se má přeložit relativní cesta. Při použití tohoto parametru vrátí rutina objekt System.Management.Automation.PathInfo pro přeloženou cestu.
Pokud použijete tento parametr s parametrem Relativní přepínač, vrátí rutina řetězec představující relativní cestu z RelativeBasePath do Path.
Tento parametr byl přidán v PowerShellu 7.4.
Typ: | String |
Position: | Named |
Default value: | None |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
Vstupy
Řetězec, který obsahuje cestu k této rutině, můžete převést.
Výstupy
Ve výchozím nastavení vrátí tato rutina objekt PathInfo .
Pokud zadáte parametr Relativní , vrátí tato rutina hodnotu řetězce pro přeloženou cestu.
Poznámky
PowerShell obsahuje následující aliasy pro Resolve-Path
:
- Všechny platformy:
rvpa
Rutiny *-Path
pracují se zprostředkovateli FileSystem, Registry a Certificate .
Resolve-Path
je navržený tak, aby fungoval s libovolným poskytovatelem. Pokud chcete zobrazit seznam poskytovatelů dostupných v relaci, zadejte Get-PSProvider
. Další informace najdete v tématu about_providers.
Resolve-Path
Řeší pouze existující cesty. Nedá se použít k překladu umístění, které ještě neexistuje.