如何通过优先考虑非零值来合并散列数组

时间:2015-09-03 10:18:00

标签: ruby

我想通过优先考虑非零值来合并哈希数组。

我是这样写的:

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}

有没有更好的方法来实现这个功能?

1 个答案:

答案 0 :(得分:0)

不,可能不是。另一种选择是

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 }