首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >PowerShell中哈希表的并集和交集

PowerShell中哈希表的并集和交集
EN

Stack Overflow用户
提问于 2015-11-20 17:28:20
回答 1查看 2.7K关注 0票数 8

在中,描述了用于数组集合操作的单行代码。

我想用哈希表来做这件事,并有一个使用字典的键集的解决方案。为了扩展到值,我使用for循环遍历键的交集,并将值复制到新的结果哈希表中。这看起来不干净。

进一步的研究表明,解决方案与GetEnumerator,这也不是干净的IMHO。

如何将臃肿的循环或枚举数替换为简洁漂亮的一行程序?

源代码如下:

http://paste.ubuntu.com/13362425/

代码语言:javascript
复制
# import csv
$a = Import-Csv -Path A.csv -Delimiter ";" -Header "Keys","Values"
$b = Import-Csv -Path B.csv -Delimiter ";" -Header "Keys","Values"

# Make nice hashtables for further use
$AData = @{}
foreach($r in $a)
  { $AData[$r.Keys] = $r.Values }
$BData = @{}
foreach($r in $b)
  { $BData[$r.Keys] = $r.Values }

# Set difference to find missing entries
$MissingA = $AData.Keys | ?{-not ($BData.Keys -contains $_)}

# I don't know how to do set-operations on hashtables yet. So use keysets and copy data (lame!)
$MissingAData = @{}
foreach($k in $MissingA)
{
    $MissingAData[$k] = $AData[$k]
}

# Intersection
$Common = $AData.Keys | ?{$BData.Keys -contains $_}
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33823151

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档