使用Powershell,我如何计算数组中每个元素的出现次数?

时间:2012-09-28 13:28:22

标签: arrays powershell scripting

如果我有一个数组:

  

1 1 1 2 2 3 4 4 4 4 5 5

如何使用Powershell告诉我该数组中每个元素有多少?

为了更清楚一点,我应该为每个数组元素分别计算:

  

元素:计数

     

1:3

     

2:2

     

3:1

     

4:4

     

5:2

3 个答案:

答案 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-Objectcalculated 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