如何解决Powershell带数字的排序对象
我有一个字符串数组,像这样的“名称:数字”,每次向该数组添加另一行但排序不起作用时,都需要按数字对它进行排序。
这个想法是,每次调用该函数时,我都会创建一个新行并将其添加到文本中。 然后,对于文本中的每一行,我在该行的前面添加数字和一个“ @”。 现在,数组是这样的:
15 @ foo:15
2 @ bar:2
4 @ foobar:4
现在,我想按编号对其进行排序,然后删除我添加的要排序的部分。
Function Add($name,$number) {
$newRow = "$($name):$number`r`n"
$Script:text = $Script:text + $newRow
ForEach($row in $text.Split("`r`n")) {
if ($row.length -ne 0) {
$rows = $rows + $row.Split(":")[1] + "@" + $row + "`r`n"
}
}
$rows | Sort-Object
ForEach($row in $rows.Split("`r`n")) {
$newText = $newText + $row.Split("@")[1] + "`r`n"
}
$textBox.Text = $newText
}
除排序外,其他所有功能都可以使用。
有人知道如何解决吗?
解决方法
您可以通过将 script块({ ... }
)传递到Sort-Object
来直接对输入进行排序,从每个输入字符串($_
)中提取数字并根据它进行排序:
PS> 'foo:15','bar:2','foobar:4' | Sort-Object { [int] ($_ -split ':')[-1] }
bar:2
foobar:4
foo:15
在您的情况下,由于这些行是多行字符串的一部分,因此您需要先将该字符串分割成几行,然后对其进行排序,然后重新加入已排序的行:
(
@'
foo:15
bar:2
foobar:4
'@ -split '\r?\n' | Sort-Object { [int] ($_ -split ':')[-1] }
) -join [Environment]::NewLine
输出看起来与上面的相同,但是在这种情况下,它不是一个排列好的行的数组,而是包含多个排列好的行的单个多行字符串。
注意:Sort-Object
输出一个 new 数组,它不会对进行排序。因此,要将排序后的数组保存回相同的变量,必须使用类似以下内容的方法:$rows = $rows | Sort-Object ...
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。