如果我有一个数组:
1 1 1 2 2 3 4 4 4 4 5 5
如何使用Powershell告诉我该数组中每个元素有多少?
为了更清楚一点,我应该为每个数组元素分别计算:
元素:计数
1:3
2:2
3:1
4:4
5:2
答案 0 :(得分:22)
您可以使用Group-Object
cmdlet:
PS> 1,1,1,2,2,3,4,4,4,4,5,5 | group
Count Name Group
----- ---- -----
3 1 {1, 1, 1}
2 2 {2, 2}
1 3 {3}
4 4 {4, 4, 4, 4}
2 5 {5, 5}
如果你想要一个项目及其计数的哈希表,你只需要一点ForEach-Object
:
$array | group | % { $h = @{} } { $h[$_.Name] = $_.Count } { $h }
答案 1 :(得分:3)
您可以根据需要调整输出并进行格式化:
PS> $ht= 1,1,1,2,2,3,4,4,4,4,5,5 | Group-Object -AsHashTable -AsString
PS> $ht
Name Value
---- -----
2 {2, 2}
4 {4, 4, 4, 4}
5 {5, 5}
1 {1, 1, 1}
3 {3}
PS> $ht['1']
1
1
1
答案 2 :(得分:2)
Joey's helpful answer提供了关键的指针:使用Group-Object
cmdlet通过相等对输入对象进行分组。
(相反,要根据其一个或多个属性值将它们分组,请使用-Property
。)
Group-Object
输出[Microsoft.PowerShell.Commands.GroupInfo]
对象,每个对象代表相等输入对象的组,其显着特性是:
.Values
...定义组的值,作为[System.Collections.ArrayList]
实例(手头仅有 1 个元素) ,因为整个输入对象 用于形成组)。
.Count
...该组中对象的数量。
如果在这种情况下无需收集单个组成员作为每个组的一部分,则可以使用
-NoElement
来提高效率。
您可以根据需要自由地进一步处理组对象;要获得问题中规定的特定输出格式,可以将Select-Object
与calculated property结合使用。
将它们放在一起:
PS> 1, 1, 1, 2, 2, 3, 4, 4, 4, 4, 5, 5 | Group-Object -NoElement |
Select-Object @{ n='Element:Count'; e={ '{0}:{1}' -f $_.Values[0], $_.Count } }
Element:Count
-------------
1:3
2:2
3:1
4:4
5:2