您可以通过遍历表并为每个键收集一个包含所有非表值的辅助数组来做到这一点。如果一个值是一个表,则重复该过程,直到遍历整个树。
t = {
a = {
1,
b = {2, 3},
4,
},
c = {5, 6, 7}
}
function rkeys(t, acc, name)
local ret = {}
for k, v in pairs(t) do
if type(v) ~= 'table' then
table.insert(ret, v)
else
rkeys(v, acc, k)
end
end
if #ret > 0 then
table.insert(acc, { [name] = ret })
end
end
function extract(t)
local ret = {}
rkeys(t, ret)
return ret
end
local result = extract(t)
for k,v in pairs(result) do
for k1,v1 in pairs(v) do
io.write(k1..": ") print("{"..table.concat(v1, ",").."}")
end
end
结果:
b: {2,3}
a: {1,4}
c: {5,6,7}
由于树被深度遍历,表中较深的表值首先出现。如果您想首先获得结果的广度,则需要使用辅助列表 [1](这将为您提供 {a, c, b})。
[1]https://www.cs.bu.edu/teaching/c/tree/breadth-first/