PowerShell 按第二个索引排序

PowerShell Sort by 2nd Index

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

预期输出示例

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。但我坚持如何正确使用它来按第二个索引排序。此示例没有任何影响,并且 returns 列表未排序。我试过在“(?:^a-z))”结尾处以不同的模式替换。到目前为止,我尝试 return 列表未排序或只是列表的一部分。 我用谷歌搜索并尝试了很多不同的东西。如果有人想帮助解决这个问题,我们将不胜感激。

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

Sort-Object 的工作原理是根据针对每个输入项计算一个或多个 属性 表达式 的结果值对每个输入进行“排名” - 在您的现有示例,基于 name 属性.

的值

正如您已经发现的那样,属性 表达式并不 必须 是任何现有 属性 的值 - 它们可以被创建什么都行 - 只需传递一个脚本块来代替 属性 名称:

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

它在您的示例中不起作用的原因是表达式 [RegEx]::Match($_.basename, "(?:^a-z))") returns 是一个 [System.Text.RegularExpressions.Match] 对象 - 无法将它们相互比较。

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

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