Condividi tramite


Resolve-Path

Risolve i caratteri jolly in un percorso e visualizza il contenuto del percorso.

Sintassi

Resolve-Path
       [-Path] <string[]>
       [-Relative]
       [-RelativeBasePath <string>]
       [-Credential <pscredential>]
       [-Force]
       [<CommonParameters>]
Resolve-Path
       -LiteralPath <string[]>
       [-Relative]
       [-RelativeBasePath <string>]
       [-Credential <pscredential>]
       [-Force]
       [<CommonParameters>]

Descrizione

Il Resolve-Path cmdlet visualizza gli elementi e i contenitori che corrispondono al modello con caratteri jolly nella posizione specificata. La corrispondenza può includere file, cartelle, chiavi del Registro di sistema o qualsiasi altro oggetto accessibile da un provider PSDrive .

Esempio

Esempio 1: Risolvere il percorso della cartella home

Il carattere tilde (~) è la notazione abbreviata per la home cartella dell'utente corrente. Questo esempio mostra Resolve-Path la restituzione del valore di percorso completo.

Resolve-Path ~

Path
----
C:\Users\User01

Esempio 2: Risolvere il percorso della cartella di Windows

Resolve-Path -Path "windows"

Path
----
C:\Windows

Quando viene eseguito dalla radice dell'unità C: , questo comando restituisce il percorso della Windows cartella nell'unità C: .

Esempio 3: Ottenere tutti i percorsi nella cartella Windows

"C:\windows\*" | Resolve-Path

Questo comando restituisce tutti i file e le cartelle nella C:\Windows cartella . Il comando usa un operatore pipeline (|) per inviare una stringa di percorso a Resolve-Path.

Esempio 4: Risolvere un percorso UNC

Resolve-Path -Path "\\Server01\public"

Questo comando risolve un percorso UNC (Universal Naming Convention) e restituisce le condivisioni nel percorso.

Esempio 5: Ottenere percorsi relativi

Resolve-Path -Path "c:\prog*" -Relative

.\Program Files
.\Program Files (x86)
.\programs.txt

Questo comando restituisce percorsi relativi per le directory nella radice dell'unità C: .

Esempio 6: Risolvere un percorso contenente parentesi quadre

In questo esempio viene utilizzato il parametro LiteralPath per risolvere il percorso della Test[xml] sottocartella. L'uso di LiteralPath comporta la rappresentazione delle parentesi quadre come caratteri normali anziché di un'espressione regolare.

Resolve-Path -LiteralPath 'test[xml]'

Esempio 7: Risolvere un percorso relativo a un'altra cartella

In questo esempio viene utilizzato il parametro RelativeBasePath per risolvere il percorso dell'eseguibile pwsh relativo a $env:TEMP. Quando il comando include il parametro switch Relativo , restituisce un valore String che rappresenta il percorso relativo da $env:TEMP all'eseguibile pwsh .

$ExecutablePath = Get-Command -Name pwsh | Select-Object -ExpandProperty Source
Resolve-Path -Path $ExecutablePath -RelativeBasePath $env:TEMP -Relative

..\..\..\..\..\Program Files\PowerShell\7\pwsh.exe

Esempio 8: Risolvere i percorsi per gli elementi nascosti

Per impostazione predefinita, non restituisce Resolve-Path elementi nascosti. In questo esempio viene utilizzato il parametro Force per risolvere gli elementi nascosti. Il Get-Item comando conferma che la .git cartella è nascosta. L'utilizzo Resolve-Path senza il parametro Force restituisce solo gli elementi visibili. L'aggiunta del parametro Force restituisce tutti gli elementi, inclusi gli elementi nascosti.

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

Parametri

-Credential

Specifica un account utente che dispone delle autorizzazioni per eseguire questa azione. Il valore predefinito è l'utente corrente.

Digitare un nome utente, ad esempio User01 o Domain01\User01, o passare un oggetto PSCredential . È possibile creare un oggetto PSCredential usando il Get-Credential cmdlet . Se si digita un nome utente, questo cmdlet richiede una password.

Questo parametro non è supportato da alcun provider installato con PowerShell.

Tipo:PSCredential
Posizione:Named
Valore predefinito:None
Necessario:False
Accettare l'input della pipeline:True
Accettare caratteri jolly:False

-Force

Consente al cmdlet di ottenere elementi a cui altrimenti non è possibile accedere dall'utente, ad esempio file nascosti o di sistema. Il parametro Force non sostituisce le restrizioni di sicurezza. L'implementazione varia a seconda del provider. Per altre informazioni, vedere about_Providers.

Questo parametro è stato aggiunto in PowerShell 7.5-preview.5.

Tipo:SwitchParameter
Posizione:Named
Valore predefinito:False
Necessario:False
Accettare l'input della pipeline:False
Accettare caratteri jolly:False

-LiteralPath

Specifica il percorso da risolvere. Il valore del parametro LiteralPath viene usato esattamente come tipizzato. Nessun carattere viene interpretato come carattere jolly. Se il percorso include caratteri di escape, racchiuderlo tra virgolette singole ('). Le virgolette singole indicano a PowerShell di non interpretare alcun carattere come sequenze di escape.

Tipo:String[]
Alias:PSPath, LP
Posizione:Named
Valore predefinito:None
Necessario:True
Accettare l'input della pipeline:True
Accettare caratteri jolly:False

-Path

Specifica il percorso di PowerShell da risolvere. Questo parametro è obbligatorio. È anche possibile inviare tramite pipe una stringa di percorso a Resolve-Path. I caratteri jolly sono consentiti.

Tipo:String[]
Posizione:0
Valore predefinito:None
Necessario:True
Accettare l'input della pipeline:True
Accettare caratteri jolly:True

-Relative

Indica che questo cmdlet restituisce un percorso relativo.

Tipo:SwitchParameter
Posizione:Named
Valore predefinito:False
Necessario:False
Accettare l'input della pipeline:False
Accettare caratteri jolly:False

-RelativeBasePath

Specifica un percorso da cui risolvere il percorso relativo. Quando si usa questo parametro, il cmdlet restituisce l'oggetto System.Management.Automation.PathInfo per il percorso risolto.

Quando si usa questo parametro con il parametro Switch Relativo , il cmdlet restituisce una stringa che rappresenta il percorso relativo da RelativeBasePath a Path.

Questo parametro è stato aggiunto in PowerShell 7.4.

Tipo:String
Posizione:Named
Valore predefinito:None
Necessario:False
Accettare l'input della pipeline:False
Accettare caratteri jolly:False

Input

String

È possibile inviare tramite pipe una stringa contenente un percorso a questo cmdlet.

Output

PathInfo

Per impostazione predefinita, questo cmdlet restituisce un oggetto PathInfo .

String

Se si specifica il parametro Relative , questo cmdlet restituisce un valore stringa per il percorso risolto.

Note

PowerShell include gli alias seguenti per Resolve-Path:

  • Tutte le piattaforme:
    • rvpa

I *-Path cmdlet funzionano con i provider FileSystem, Registry e Certificate .

Resolve-Path è progettato per funzionare con qualsiasi provider. Per elencare i provider disponibili nella sessione, digitare Get-PSProvider. Per altre informazioni, vedere about_providers.

Resolve-Path risolve solo i percorsi esistenti. Non può essere usato per risolvere un percorso che non esiste ancora.