PowerShell按第二个索引排序

问题描述

我正在尝试按名称的第二个索引对服务器进行排序。 服务器名称取自文件路径,它们是文件的基本名称。 我知道Select-Object具有参数-Index,但是我认为这不起作用。 我假设最好的方法是使用PowerShell RegEx,例如“(?:^ a-z))”。这将返回未排序的列表,我仍在四处寻找将按第二个索引排序的模式。

预期输出示例

  • 名称CC或DD对服务器进行分组
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。但是我一直在坚持如何正确地使用它来对第二个索引进行排序。本示例不起作用,并且返回未排序的列表。我试过以“(?:^ a-z))”结尾的不同模式显示。到目前为止,我的尝试要么返回未排序的列表,要么仅返回列表的一部分。 我在Google周围搜索并尝试了许多不同的方法。如果有人想帮助解决这个问题,将不胜感激。

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

解决方法

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}