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来直接对输入进行排序,enter image description here从每个输入字符串($_)中提取数字并根据它进行排序:

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 ...