首页 > 解决方案 > PowerShell 按第二个索引排序

问题描述

我正在尝试按名称的第二个索引对服务器进行排序。服务器名称取自文件路径,它们是文件的 BaseName。我知道 Select-Object 有参数 -Index,但我认为这行不通。我假设最好的方法是使用像“(?:^az))”这样的 PowerShell RegEx。这将返回一个未排序的列表,我仍在谷歌搜索将按第二个索引排序的模式。

预期输出示例

Server        
------        
ABCCWS01
CDCCWS01
ABDDWS01
CDDDWS01

电流输出

$servers = Get-Item -Path
C:\ABDDWS01.ServerData, 
C:\ABCCWS01.ServerData, 
C:\CDCCWS01.ServerData, 
C:\CDDDWS01.ServerData | Group BaseName -AsHashtable

foreach($computer in $servers.GetEnumerator() | Sort-Object -Property name)
{ ...DoSomething... }

Server        
------        
ABCCWS01
ABDDWS01
CDCCWS01
CDDDWS01

然后我尝试实现一个 PowerShell RegEx。但我坚持如何正确使用它来按第二个索引排序。此示例没有影响并返回未排序的列表。我已经尝试在结尾“(?:^ az))”以不同的模式进行替换。到目前为止,我的尝试要么返回未排序的列表,要么只返回列表的一部分。我用谷歌搜索并尝试了许多不同的东西。如果其他人想帮助解决这个问题,非常感谢。

Sort-Object -Property @{Expression={[RegEx]::Match($_.basename, "(?:^a-z))")}}

标签: regexpowershellsortingmatchsort-object

解决方案


Sort-Object通过根据针对每个输入项计算一个或多个属性表达式的结果值“排名”每个输入- 在您现有的示例中,基于name属性的值。

正如您已经发现的那样,属性表达式不必任何现有属性的值——它们可以由任何东西组成——只需传递一个脚本块来代替属性名称:

... |Sort-Object -Property {$_.name[1]}

它在您的示例中不起作用的原因是该表达式[RegEx]::Match($_.basename, "(?:^a-z))")返回一个[System.Text.RegularExpressions.Match]对象 - 并且这些对象之间无法进行有意义的比较。

如果您更改表达式以解析为字符串(例如匹配的值),它将起作用:

... |Sort-Object -Property @{Expression={[RegEx]::Match($_.basename, "(?:^a-z))").Value}}
# or
... |Sort-Object -Property {[RegEx]::Match($_.basename, "(?:^a-z))").Value}

推荐阅读