我想通过仅将初始表作为参数传递来遍历不同的索引表。 我目前有这张桌子:
local table = {
stuff_1 = {
categories = {},
[1] = {
name = 'wui',
time = 300
}
},
stuff_2 = {
categories = {'stuff_10', 'stuff_11', 'stuff_12'},
stuff_10 = {
categories = {},
[1] = {
name = 'peo',
time = 150
},
[2] = {
name = 'uik',
time = 15
},
[3] = {
name = 'kpk',
time = 1230
},
[4] = {
name = 'aer',
time = 5000
}
},
stuff_11 = {
categories = {},
[1] = {
name = 'juio',
time = 600
}
},
stuff_12 = {
categories = {},
[1] = {
name = 'erq',
time = 980
},
[2] = {
name = 'faf',
time = 8170
}
}
}
我想创建一个递归函数来检查这些表中的名称是否等于某些特定的东西并返回一个字符串。 递归性在于使用我喜欢的任何数据(或直到某个限制)来更新此表的想法。 我不知道自从我尝试以来出了什么问题:
for k, v in pairs(table) do
print(k, v, #v.categories)
end
正确打印:
stuff_2 table: 0x10abb0 3
stuff_1 table: 0x10aab8 0
但是当将表作为参数传递给下面的函数时,会出现此错误:
[string "stdin"]:84: attempt to get length of field 'categories' (a nil value)
功能:
function checkMessage(table)
local i = 1
local message = ""
for k, v in pairs(table) do
if(#v.categories == 0) then
while(v[i]) do
if(v[i].name == 'opd') then
if(v[i].time ~= 0) then
message = "return_1"
else
message = "return_2"
end
end
i = i + 1
end
else
checkMessage(table[k])
end
end
return message
end
编辑:问题在于不忽略当在表上使用对时,这并不只是具有类别子表的表,但它也有一个名为category的表,如果忽略这个,那么问题就解决了
答案 0 :(得分:3)
您已经递归到没有categories
字段的子表格中。尝试访问categories
会产生nil
,然后您尝试使用长度运算符。因此你的错误:
attempt to get length of field 'categories' (a nil value)
如果您无法跟踪您的应用,请输入更多打印语句或获取行级调试器。