前任写了一些表,不仅仅是定义的时候确定了表结构,可能在过程中会再处理一下表。怎么能快速的知道表结构,避免时间的浪费。我因为查看表结构已经 delay。。。
1
mpich 2017-11-16 10:37:13 +08:00
前任。。。
|
3
YyYyYyy 2017-11-16 10:46:47 +08:00
手写 recursively table print 不可避
|
4
changnet 2017-11-16 10:53:06 +08:00
```lua
local function to_readable( val ) if type(val) == "string" then return "\"" .. val .. "\"" end return val end --- @param data 要打印的字符串 --- @param [max_level] table 要展开打印的计数,默认 nil 表示全部展开 --- @param [prefix] 用于在递归时传递缩进,该参数不供用户使用于 local recursion = {} local function var_dump(data, max_level, prefix) if type(prefix) ~= "string" then prefix = "" end if type(data) ~= "table" then print(prefix .. tostring(data)) elseif recursion[data] then print(data,"dumplicate") --重复递归 else recursion[data] = true print(data) local prefix_next = prefix .. " " print(prefix .. "{") for k,v in pairs(data) do io.stdout:write(prefix_next .. tostring( to_readable(k) ) .. " = ") if type(v) ~= "table" or (type(max_level) == "number" and max_level <= 1) then print( to_readable(v) ) else var_dump(v, max_level - 1, prefix_next) end end print(prefix .. "}") end end --[[ eg: local b = {aaa="aaa",bbb="bbb",ccc="ccc"} ]] function vd(data, max_level) var_dump(data, max_level or 20) recursion = {} --释放内存 end ``` |
6
gdzzzyyy OP @changnet 我的意思就是遇见一个 table 就要 debug 出结构太麻烦了。感觉这也是唯一方法。
就怕在用的过程被什么地方修改了。 |
7
YyYyYyy 2017-11-16 11:22:42 +08:00
@gdzzzyyy 想要监听增删?重写元方法__newindex
想要监听修改?那你得在用这张表开始就重写__newindex 并把之后所有要加的键值全部移到一张内部代理表里。 在这种情况下还得重写__index 来修正读取。 |
8
knightdf 2017-11-16 12:02:23 +08:00
在函数输入注释上把表结构写上去,然后用 cjson 把表打出来看结构
|