Recursion 为什么Lua在递归函数的表内创建表?
我想将Recursion 为什么Lua在递归函数的表内创建表?,recursion,lua,Recursion,Lua,我想将表中的每个值替换为另一个值。我的代码: function substitute_in_table(requests) local function helper(r, result) for k, v in pairs(r) do if type(v) == "table" then result[k] = helper(v, result) else r
表中的每个值替换为另一个值。我的代码:
function substitute_in_table(requests)
local function helper(r, result)
for k, v in pairs(r) do
if type(v) == "table" then
result[k] = helper(v, result)
else
result[k] = 'someValue'
end
end
return result
end
return helper(requests, {})
end
r = {
request = {
headers = "a",
body = "b"
}
}
result = substitute_in_table(r)
print(inspect(result))
结果,我得到了如下表格:
{
headers = "someValue"
body = "someValue",
request = {
headers = "someValue"
body = "someValue"
}
}
但预期的结果是
request = {
headers = "someValue"
body = "someValue"
}
看来你应该换线了
result[k] = helper(v, result)
进入
所以,您可以将子表复制到新表中,然后将结果插入到原始表中,而不是将子表直接复制到原始表中
result[k] = helper(v, {})