如何循环遍历哈希表中的哈希?

89

我有这个哈希表:

 h
 => {"67676.mpa"=>{:link=>"pool/sdafdsaff", :size=>4556}} 

>  h.each do |key, value|
>     puts key
>   puts value
>   end
67676.mpa
linkpool/sdafdsaffsize4556

我如何在循环中访问值哈希中的各个值?


1
你想看到什么输出? - Mark Thomas
Appcoach Shingara使用得非常好...我一定是想不到...答案就在我的面前...我必须做一个内部循环。 - Matt Elhotiby
众所周知,puts在散列表上的输出几乎没有用处,你试过“puts hash.inspect”吗? - tokland
5个回答

171

Value is a Hash to so you need iterate on it or you can get only values:-

h.each do |key, value|
  puts key
  value.each do |k,v|
    puts k
    puts v
  end
end

或者

h.each do |key, value|
  puts key
  value.values.each do |v|
    puts v
  end
end


如果key在任何地方都没有被使用,那么怎么办呢?我们需要在key的位置上放一个?吗?例如:|?, array| 这是Ruby中的有效语法吗? - huzefa biyawarwala
如果在迭代中未使用键,则应该在其前面加下划线,例如 |_key, value|。@huzefabiyawarwala - Severin

18

您需要通过哈希表进行递归,以下是一个递归方法:

def ihash(h)
  h.each_pair do |k,v|
    if v.is_a?(Hash)
      puts "key: #{k} recursing..."
      ihash(v)
    else
      # MODIFY HERE! Look for what you want to find in the hash here
      puts "key: #{k} value: #{v}"
    end
  end
end

您可以随后将任何哈希值传递进来:

h = {
    "x" => "a",
    "y" => {
        "y1" => {
            "y2" => "final"
        },
        "yy1" => "hello"
    }
}
ihash(h)

如果key在任何地方都没有使用,我们需要怎么办?我们需要在key的位置上放置一个?吗?例如:|?, array|这种语法是有效的吗? - huzefa biyawarwala
保留它,只是不要使用它。问号无效。 - Travis Reeder

9
我稍微改进了Travis的答案,这是一个代码片段示例:

https://gist.github.com/kjakub/be17d9439359d14e6f86

class Hash

  def nested_each_pair
    self.each_pair do |k,v|
      if v.is_a?(Hash)
        v.nested_each_pair {|k,v| yield k,v}
      else
        yield(k,v)
      end
    end
  end

end

{"root"=>{:a=>"tom", :b=>{:c => 1, :x => 2}}}.nested_each_pair{|k,v|
  puts k
  puts v
}

@Travis R 改进了答案。 - Jakub Kuchar

5
在这种情况下,分离所有三个值的最简单方法如下所示:
h.each do |key, value|
  puts key
  puts value[:link]
  puts value[:size]
end

2
您可以通过调用hash.values直接访问哈希表的值。在这种情况下,您可以采取以下操作:
> h = {"67676.mpa"=>{:link=>"pool/sdafdsaff", :size=>4556}}
> h.values.each do |key, value|
>   puts "#{key} #{value}"
> end

link pool/sdafsaff
size 4556

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接