【发布时间】:2020-10-09 03:20:16
【问题描述】:
我有一个这样的哈希:
hash = {
'en-us': {
where: 'USA'
},
'en-us-zone2': {
where: 'USA'
},
'en-nl': {
where: 'Netherlands'
},
'en-pt': {
where: 'Portugal'
},
}
我尝试使用group_by 对它们进行分组:
result = hash.group_by { |k,v| v[:where] }
但是,它返回完整的数组而不是哈希数组。所以这里是预期和实际的结果:
实际结果:
{ "USA"=>
[[:"en-us", {:where=>"USA"}], [:"en-us-zone2", {:where=>"USA"}]],
"Netherlands"=>
[[:"en-nl", {:where=>"Netherlands"}]],
"Portugal"=>
[[:"en-pt", {:where=>"Portugal"}]]
}
预期结果:
{ "USA"=>
[{:"en-us" => {:where=>"USA"}}, {:"en-us-zone2" => {:where=>"USA"}}]
"Netherlands"=>
[{:"en-nl" => {:where=>"Netherlands"}}]
"Portugal"=>
[{:"en-pt" => {:where=>"Portugal"}}]
}
请看,Actual 是数组数组,而不是哈希数组。哈希键成为第一个数组元素。
如何根据:where 对我的哈希进行分组?
【问题讨论】: