// 扁平化 JSON 对象 //(想要将嵌套哈希中的所有键合并为字符串,并希望将其放入数组列表中)
input1 = {a: {b: {c: {} }, d:[] }, e: "e", f: nil, g: -2}
input2 = {a: {b: {c: {h: {j: ''}, m: {n: ''}}}, d: {k: {l: '' } }},e: "e",f: nil,g: -2}
// 上述输入的预期输出,应该是一个包含所有这些键(按任意顺序)的数组
output1 = ["g", "f", "e", "a.b.c", "a.d"]
output2 = ["a.b.c.h.j", "a.b.c.m.n", "a.d.k.l", "e", "f", "g"]
创建一种方法
def flatten_hash_keys(hash, prefix = nil)
flat_keys = []
hash.each do |key, value|
current_key = prefix ? "#{prefix}.#{key}" : key.to_s
if value.is_a?(Hash) && !value.empty?
flat_keys.concat(flatten_hash_keys(value, current_key))
else
flat_keys << current_key
end
end
flat_keys
end
此代码定义了一个 flatten_hash_keys 方法,该方法采用哈希值和可选前缀。它递归地遍历哈希,将键附加到 flat_keys 数组中。如果值是非空哈希,则使用新前缀递归调用该方法。否则,当前键将添加到数组中
input1 = {a: {b: {c: {} }, d:[] }, e: "e", f: nil, g: -2}
input2 = {a: {b: {c: {h: {j: ''}, m: {n: ''}}}, d: {k: {l: '' } }},e: "e",f: nil,g: -2}
output1 = flatten_hash_keys(input1) #["a.b.c", "a.d", "e", "f", "g"]
output2 = flatten_hash_keys(input2) #["a.b.c.h.j", "a.b.c.m.n", "a.d.k.l", "e", "f", "g"]