8

PowerShell 中是否有用于转义路径中的字符的功能?

注意:我知道大多数提供Path参数的 cmdlet 也提供了LiteralPath解决此问题的参数。这个问题更多是出于好奇而不是需要,因为在我能想到的大多数用例中,切换到LiteralPath是有道理的。然而,有一些真正的用例(例如,Start-BitsTransfer有一个Source参数,但没有文字等价物)。

细节

如果我有一个 file c:\temp\test[0123].txt,而不是Get-Item 'c:\temp\test[0123].txt',我必须使用Get-Item 'c:\temp\test`[0123`].txt'来获得结果(或使用LiteralPath参数)。

甚至另一个 PowerShell 命令返回的路径也会返回一个未转义的字符串;即Get-ChildItem 'c:\temp\' -Filter 'test*.txt' | Convert-Path | Get-Item失败(注意:如果我们传递实际FileSystemInfo对象所有工作,但该对象没有具有正确转义字符串路径的属性)。

我们可以使用下面的代码轻松地逃避它:

$path = 'c:\temp\test[0123].txt'
$path = $path -replace '([][[])', '`$1' # escape square brackets by adding back ticks
Get-Item $path

但是,在转义字符串时,标准建议是避免滚动您自己的解决方案/使用语言的解决方案来解决这些问题。

PowerShell 中是否有任何预先存在的功能用于此目的,或任何推荐的解决方法;或者是使用定制功能的唯一选择(例如下面)?

function ConvertFrom-LiteralPath {
    [CmdletBinding()]
    param (
        [Parameter(Mandatory = $true, ValueFromPipeline = $true)]
        [string]$LiteralPath
    )
    process {
        (New-Object -TypeName 'PSObject' -Property @{
            LiteralPath = $LiteralPath
            Path = $LiteralPath -replace '([][[\*\?])', '`$1' # escapes ], [, *, and ?
        })
    }
}

特殊字符的相关资料:

4

1 回答 1

13

您可以使用以下方法:

[Management.Automation.WildcardPattern]::Escape('test[1].txt')

回报:

test`[1`].txt

记录在这里:
https ://docs.microsoft.com/en-us/dotnet/api/system.management.automation.wildcardpattern.escape

于 2017-09-04T12:54:26.360 回答