繁体   English   中英

组对象,获取计数

[英]Group-Object, get counts

给定一个包含一些重复项目的列表,我可以使用Group-Object -AsHashtable并得到一个 hash 表,该表似乎具有项目名称的键,而值是我不认识的。

所以,给定

$array = [System.Collections.Generic.List[String]]@('A', 'B', 'C', 'B', "c", 'C')
$grouped = $array | Group-Object -AsHashTable

$grouped将是

Name                           Value                                                                                                                                                                                                                                              
----                           -----                                                                                                                                                                                                                                              
A                              {A}                                                                                                                                                                                                                                                
B                              {B, B}                                                                                                                                                                                                                                             
C                              {C, c, C}  

那时我会认为$grouped['B'].Count$grouped.'B'.Count会产生正确的计数 2。但我得到 0。我错过了什么?

Windows PowerShell中看到了一个错误,该错误已在PowerShell(核心)7+中修复 - 请参阅ZD3B7C9233CD04EBFEC0EEC9的详细信息。

解决方法:在 Windows PowerShell 中,始终将-AsHashTable-AsString结合使用,即使输入对象或分组属性值已经字符串。 亚伯拉罕·齐纳拉致敬

PS> ('A', 'B', 'C', 'B', "c", 'C' | Group-Object -AsHashTable -AsString).B.Count

2 # OK, thanks to -AsString (not necessary in PowerShell 7+)

这绕过了该错误,否则该错误表现如下:旨在成为哈希表键的字符串意外地包装在不可见的[psobject]包装器中,这反过来又阻止了基于字符串的键查找。

注意:这意味着如果您希望键是字符串以外的数据-AsHashtable (例如[int] ),则不能在 Windows PowerShell 中使用 -AsHashtable ,因为对于此类数据类型,无法绕过不可见的[psobject]包装。

试试下面的(它对我有用,见图片)

$array = [System.Collections.Generic.List[String]]@('A', 'B', 'C', 'B', "c", 'C')
$grouped = $array | Group-Object -AsHashTable
$grouped.B 
$grouped.B.Count

Write-Host $grouped.B.Count

$b = $grouped.B.Count
Write-Host "The Number of Values in Column B Is - $b"

在此处输入图像描述

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM