加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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 }

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读