我想将嵌套的哈希值转换为多维数组recursivley。
这是我目前的代码:
def deep_to_a(hash)
return hash.to_a.each {|k, v|
if k.is_a?(Hash) then
hash[k.to_a] = hash.delete(k)
deep_to_a(k)
elsif v.is_a?(Hash) then
hash[k] = hash[k].to_a
if hash[k].any?{|k, v| k.is_a?(Hash) || v.is_a?(Hash)}
deep_to_a(v)
end
end
}
end
我想得到:
h = {11=>{12=>13, 14=>15}, 16=>17}
p deep_to_a(h) # => [[11, [[12, 13], [14, 15]]], [16, 17]]
但是我得到了
[[11, {12=>13, 14=>15}], [16, 17]]
我怎样才能让它发挥作用?
答案 0 :(得分:1)
破坏性功能很难调试。
在这种情况下,map
优于each
+破坏性分配。
hash.to_a
的结果是一个数组,因此您的迭代|k, v|
不正确。
def deep_to_a(hash)
hash.map do |v|
if v.is_a?(Hash) or v.is_a?(Array) then
deep_to_a(v)
else
v
end
end
end
h = {11=>{12=>13, 14=>15}, 16=>17}
p deep_to_a(h)
# [[11, [[12, 13], [14, 15]]], [16, 17]]
答案 1 :(得分:0)
def deep_to_a(h)
h.map { |k,v| [k, Hash === v ? deep_to_a(v) : v] }
end
deep_to_a({11=>{12=>13, 14=>15}, 16=>17})
#=> [[11, [[12, 13], [14, 15]]], [16, 17]]