我有一系列哈希:
[{"folder"=>"j"}, {"path"=>"p"}, {"folder"=>"b"}]
我通过以下方式合并它们:
flat_map(&:entries)
.group_by(&:first)
.map{|k,v| Hash[k, v.map(&:last)]}
然后我得到:
[{"folder"=>["j", "b"]}, {"path"=>["p"]}]
正如所料。
我的问题是,:folder
和:path
(我也会有更多的密钥)可以随机排序。而不是循环和检查键名,是否可以单独获取每个哈希?例如;
# After merging...
folders = elem[:folder] # => ["j", "b"]
paths = elem[:path].. # => ["p"]
基本上我想让:folder
和:path
一直没有循环。
答案 0 :(得分:2)
您可以通过以下方式解决问题:
elem = [{"folder"=>["j", "b"]}, {"path"=>["p"]}]
merged = elem.reduce({}, :merge)
# => {"folder" => ["j", "b"], "path" => ["p"]}
merged["folder"]
# => ["j", "b"]
merged["path"]
# => ["p"]
答案 1 :(得分:2)
您可以首先使用不同的方法:
collection = [{"folder"=>"j"}, {"path"=>"p"}, {"folder"=>"b"}]
使用each_with_object
(或与reduce
类似的方法):
collection.each_with_object({}) do |values, s|
values.each do |key, value|
(s[key.to_sym] ||= []) << value
end
end
{{3}}
或group_by
和transform_values
:
collection.
group_by { |item| item.first.first.to_sym }.
transform_values { |values| values.flat_map(&:values) }
答案 2 :(得分:2)
ar =[{"folder"=>"j"}, {"path"=>"p"}, {"folder"=>"b"}]
elem = Hash.new{[]}
ar.each{|hash| hash.each{|k,v| elem[k] <<= v }}
folders, paths = elem.values_at("folder", "path")