簡體   English   中英

散列哈希的Ruby哈希

[英]Ruby hash of hash of hash

我怎么能有哈希哈希的哈希?

我的測試回來了

未定義的方法`[]'為nil:NilClass(NoMethodError)

有小費嗎?

found = Hash.new()
x = 1;

while x < 4 do
  found[x] = Hash.new()
  y = 1

  while y < 4 do
    found[x][y] = Hash.new()
    found[x][y]['name1'] = 'abc1'
    found[x][y]['name2'] = 'abc2'
    found[x][y]['name3'] = 'abc3'

    y += 1
  end

  x += 1
end

found.each do |k, v, y|
  puts "k : #{k}"
  puts "  : #{v[y['name1']]}"
  puts "  : #{v[y['name2']]}"
  puts "  : #{v[y['name3']]}"
  puts
end

構建哈希的方式似乎是有用的。 可能導致錯誤的是這個循環:

found.each do |k, v, y|

Hash#each產生鍵/值對,因此y將被指定為nil ,從而導致錯誤下面兩行。 你可能意味着什么是嵌套循環

found.each do |x, h1|
  h1.each do |y, h2|
    puts h2['name1']
  end
end

您還應該知道,您可以在Ruby中更簡潔地編寫這些類型的計數循環:

found = Hash.new { |h,k| h[k] = {} }

1.upto(3) do |x|
  1.upto(3) do |y|
    found[x][y] = {
      'name1' => 'abc1',
      'name2' => 'abc2',
      'name3' => 'abc3',
    }
  end
end

我想你想要這樣的東西:

首先創建數據結構。 您需要嵌套哈希,因此您需要為每個哈希鍵定義默認值。

found = Hash.new do |hash,key| 
    hash[key] = Hash.new do |hash,key|
        hash[key] = Hash.new
    end
end

運行搜索

(1..3).each do |x|
  (1..3).each do |y|
    found[x][y]['name1'] = 'abc1'
    found[x][y]['name2'] = 'abc1'
    found[x][y]['name3'] = 'abc1'    
  end
end

然后顯示結果

found.each do |x, y_hash|
  y_hash.each do |y, name_hash|
    name_hash.each do |name, value|
      puts "#{x} => #{y} => #{name} => #{value}"
    end
  end
end

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM