我有一个哈希 hash
像这样:
hash = {"Addaptive Accessibility"=>["one","two"],
"Atmosphere (Feeling/Safety)"=>["three", "four"],
"Aquatics (Size)"=>["five", "six"]}
然后我有一个数组array
:
array = ["one","seven"]
我需要在散列中搜索数组中的每个单词,如果找到该单词,我需要从散列中返回关联的 key
。像这样:
array.each do |word|
if hash.include? word
puts key
end
end
我怎样才能写得更好?
最佳答案
为了回答您最初的问题,我将提出另一个我认为最容易理解的解决方案:
hash.find{|k,v| v.include? word }.first
这只会迭代直到找到匹配项,即您可能会节省几个周期。与@ArupRakshit 的解决方案相反,这只会找到第一个 匹配项。
但是我必须强调,您确实在错误的方向上使用了散列——只是翻转键和值!
关于ruby - 如果散列包含 Ruby 中的值,则返回散列键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19469586/