递归打印表格

我正在尝试打印一个可能包含表格的表格。但是,我无法递归地打印它。

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
            -- 如果是表格就递归调用
            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

这让我感到困惑,因为我期望得到比我得到的更深层次的树。 我缺少什么?

点赞
用户3735873
用户3735873

我认为你有一个小的“错误”,它只是把它平铺了。将

debugTable(v, " - ");

改为(类似于)

debugTable(v, ind..'-- ')

你就可以看到真正的深度了。

10 11
11 11
12 10
-- 1 10
-- -- -- 33 44
-- -- -- 55 43
-- -- 12 30
-- -- 11 40
2017-02-04 22:11:54
用户5113346
用户5113346

在存在大量深度嵌套的表格时,使用该方法最终会导致堆栈溢出。如果输出字符串变得太大,巨大的表格也会在字符串连接期间引起“内存不足”错误。如果你遇到了这个问题,你可以尝试我的答案:如何将一个表格转储到控制台?

2017-02-06 08:18:42