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, {})