regex - PowerShell 按第二个索引排序
问题描述
我正在尝试按名称的第二个索引对服务器进行排序。服务器名称取自文件路径,它们是文件的 BaseName。我知道 Select-Object 有参数 -Index,但我认为这行不通。我假设最好的方法是使用像“(?:^az))”这样的 PowerShell RegEx。这将返回一个未排序的列表,我仍在谷歌搜索将按第二个索引排序的模式。
预期输出示例
- 按名称 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。但我坚持如何正确使用它来按第二个索引排序。此示例没有影响并返回未排序的列表。我已经尝试在结尾“(?:^ az))”以不同的模式进行替换。到目前为止,我的尝试要么返回未排序的列表,要么只返回列表的一部分。我用谷歌搜索并尝试了许多不同的东西。如果其他人想帮助解决这个问题,非常感谢。
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}
推荐阅读
- c# - 如何检查值是否包含特定字母并相应地更新值
- jetty - 地理服务器和迁移到 HTTPS
- mongoose - 将对象数组添加到突变 react-graphql-apollo-mongoose 时,“无法读取未定义的属性 'get'”
- python - 张量流无法导入
- python - 传递给参数“shape”的值的数据类型 float32 不在允许值列表中:int32、int64
- amazon-web-services - AWS S3 超出限制 - 如何更改层类型?
- node.js - 使用Nodejs将JSON对象存储在MySql2的JSON列中
- entity-framework - 实体框架核心迁移
- java - 使用@OneToMany 或@ManyToMany 定位未映射的类(多数据库连接)
- javascript - $filter() 如何在 angularjs 内部工作?