ruby – 如何通过优先考虑非零值来合并散列数组
发布时间:2020-12-17 01:55:42 所属栏目:百科 来源:网络整理
导读:我想通过优先考虑非零值来合并哈希数组. 我写的是这样的: hs = [{a: 1,b:2,c: nil},{a: nil,b:nil,c:3},{d: nil,e: 5}]hs.reduce{|v1,v2| v1.merge(v2){|k,old,new| old || new} }# = {:a=1,:b=2,:c=3,:d=nil,:e=5} 有没有更好的方法来实现这个功能? 解决
我想通过优先考虑非零值来合并哈希数组.
我写的是这样的: hs = [{a: 1,b:2,c: nil},{a: nil,b:nil,c:3},{d: nil,e: 5}] hs.reduce{|v1,v2| v1.merge(v2){|k,old,new| old || new} } # => {:a=>1,:b=>2,:c=>3,:d=>nil,:e=>5} 有没有更好的方法来实现这个功能? 解决方法
不,可能不是.另一种选择
hs = [{ a: 1,b: 2,c: nil },{ a: nil,b: nil,c: 3 },{ d: nil,e: 5 }] hs.map(&:to_a) .flatten(1) .partition { |_,v| !v } .flatten(1) .to_h # => { :c => 3,:a => 1,:b => 2,:d => nil,:e => 5 } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |