PowerShell 按第二个索引排序
PowerShell Sort by 2nd Index
我正在尝试按名称的第二个索引对服务器进行排序。
服务器名称取自文件路径,它们是文件的 BaseName。
我知道 Select-Object 有参数 -Index,但我认为这行不通。
我假设最好的方法是使用像“(?:^a-z))”这样的 PowerShell RegEx。这个 return 是一个未排序的列表,我仍在谷歌上搜索将按第二个索引排序的模式。
预期输出示例
- 按名称 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。但我坚持如何正确使用它来按第二个索引排序。此示例没有任何影响,并且 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}
我正在尝试按名称的第二个索引对服务器进行排序。 服务器名称取自文件路径,它们是文件的 BaseName。 我知道 Select-Object 有参数 -Index,但我认为这行不通。 我假设最好的方法是使用像“(?:^a-z))”这样的 PowerShell RegEx。这个 return 是一个未排序的列表,我仍在谷歌上搜索将按第二个索引排序的模式。
预期输出示例
- 按名称 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。但我坚持如何正确使用它来按第二个索引排序。此示例没有任何影响,并且 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}