如何避免NoMethodError嵌套散列中缺失的元素,无需重复零检查? [英] How to avoid NoMethodError for missing elements in nested hashes, without repeated nil checks?

查看:82
本文介绍了如何避免NoMethodError嵌套散列中缺失的元素,无需重复零检查?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在寻找一种避免在深度嵌套哈希的每个级别检查 nil 的好方法。例如:

  name = params [:company] [:owner] [:name] if params [:company]& &安培; params [:company] [:owner]&& params [:company] [:owner] [:name] 

这需要三次检查,非常丑陋的代码。任何方式来解决这个问题?

解决方案

Ruby 2.3.0引入了一个名为 dig 的新方法 Hash $ b 完全解决了这个问题。 params.dig(:company,:owner,:name)

它返回 nil 如果在任何级别缺失密钥。



如果您使用的是早于2.3的Ruby版本,则可以使用 ruby​​_dig gem 或自行实施:

 模块RubyDig 
def dig(key,* rest)
if value =(self [key] rescue nil)
if rest.empty?
value
elsif value.respond_to?(:dig)
value.dig(* rest)
end
end
end
end

如果RUBY_VERSION< '2.3'
Array.send(:include,RubyDig)
Hash.send(:include,RubyDig)
end


I'm looking for a good way to avoid checking for nil at each level in deeply nested hashes. For example:

name = params[:company][:owner][:name] if params[:company] && params[:company][:owner] && params[:company][:owner][:name]

This requires three checks, and makes for very ugly code. Any way to get around this?

解决方案

Ruby 2.3.0 introduced a new method called dig on both Hash and Array that solves this problem entirely.

name = params.dig(:company, :owner, :name)

It returns nil if the key is missing at any level.

If you are using a version of Ruby older than 2.3, you can use the ruby_dig gem or implement it yourself:

module RubyDig
  def dig(key, *rest)
    if value = (self[key] rescue nil)
      if rest.empty?
        value
      elsif value.respond_to?(:dig)
        value.dig(*rest)
      end
    end
  end
end

if RUBY_VERSION < '2.3'
  Array.send(:include, RubyDig)
  Hash.send(:include, RubyDig)
end

这篇关于如何避免NoMethodError嵌套散列中缺失的元素,无需重复零检查?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆