Печать рекурсивных таблиц
Я пытаюсь напечатать таблицу, может содержать таблицы. Тем не менее, я не могу заставить его печатать рекурсивно.
function debugTable (t, indent)
local ind = indent or "";
local printFunc = print
if (fibaro or {}).debug then
function printFunc(...)
return fibaro:debug(...)
end
end
for k, v in pairs(t) do
if(type(v) == "table") then
-- recursive call if table
debugTable(v, " - ");
else
printFunc(ind .. k .." ".. tostring(v));
end;
end;
end;
Это тестовая таблица:
a = {};
c ={["33"] = 44,["55"]=43}
b = {["12"] = 30, ["11"]= 40,["66"]=c};
a["12"] = 10;
a["10"] = 11;
a["22"] = {10,["13"]=b};
a["11"] = 11;
теперь, когда я печатаю таблицу, я получаю это:
> debugTable(a)
- 1 10
- 12 30
- 33 44
- 55 43
- 11 40
12 10
10 11
11 11
что озадачивает меня, так как я ожидал более глубокое дерево, чем то, что я получил. Чего мне не хватает?
2 ответа
Я думаю, что у вас есть небольшая ошибка, которая просто сгладила это. + Изменить
debugTable(v, " - ");
чтобы (что-то вроде)
debugTable(v, ind..'-- ')
и вы видите истинную глубину.
10 11
11 11
12 10
-- 1 10
-- -- -- 33 44
-- -- -- 55 43
-- -- 12 30
-- -- 11 40
С большим количеством глубоко вложенных таблиц вы в конечном итоге переполните стек, используя этот метод. Огромные таблицы также вызовут ошибку "недостаточно памяти" во время конкатенации строк, если выходная строка станет слишком большой. Если вы столкнулись с этой проблемой, вы можете попробовать мой ответ здесь: Как вывести таблицу на консоль?