79

我需要合并两个表,如果给定项目在两个表中,则第二个表的内容会覆盖第一个表中的内容。我看了,但标准库似乎没有提供这个。我在哪里可以获得这样的功能?

4

9 回答 9

112
for k,v in pairs(second_table) do first_table[k] = v end
于 2009-08-16T03:29:24.670 回答
19

这是我根据 Doug Currie 的回答得出的结论:

function tableMerge(t1, t2)
    for k,v in pairs(t2) do
        if type(v) == "table" then
            if type(t1[k] or false) == "table" then
                tableMerge(t1[k] or {}, t2[k] or {})
            else
                t1[k] = v
            end
        else
            t1[k] = v
        end
    end
    return t1
end
于 2009-08-16T06:26:35.867 回答
13

这不能正常工作吗?


function merge(t1, t2)
    for k, v in pairs(t2) do
        if (type(v) == "table") and (type(t1[k] or false) == "table") then
            merge(t1[k], t2[k])
        else
            t1[k] = v
        end
    end
    return t1
end
于 2011-09-19T12:16:48.397 回答
7

对于数字索引表合并:

for k,v in pairs(secondTable) do table.insert(firstTable, v) end
于 2016-03-22T04:07:02.003 回答
4

对于大多数情况,Doug Currie 的回答是最简单的。如果您需要更健壮的表格合并,请考虑使用Penlight库中的merge()方法。

require 'pl'
pretty.dump(tablex.merge({a=1,b=2}, {c=3,d=4}, true))

-- {
--   a = 1,
--   d = 4,
--   c = 3,
--   b = 2
-- }
于 2014-05-27T14:03:28.313 回答
3

我更喜欢 James 版本的简单性,并在我的 utils.lua 中使用它——我确实添加了检查表类型以进行错误处理。

function merge(a, b)
    if type(a) == 'table' and type(b) == 'table' then
        for k,v in pairs(b) do if type(v)=='table' and type(a[k] or false)=='table' then merge(a[k],v) else a[k]=v end end
    end
    return a
end

感谢这个不错的函数,它应该是表类的一部分,所以你可以打电话a:merge(b),但这样table.merge = function(a, b) ...做对我不起作用。对于真正的书呆子,甚至可以压缩到一个衬里:)

于 2015-03-18T22:09:17.853 回答
3

这是深度合并的迭代版本,因为我不喜欢递归的潜在堆栈溢出。

local merge_task = {}
function merge_to_left_o(orig, new)
   merge_task[orig] = new

   local left = orig
   while left ~= nil do
      local right = merge_task[left]
      for new_key, new_val in pairs(right) do
         local old_val = left[new_key]
         if old_val == nil then
            left[new_key] = new_val
         else
            local old_type = type(old_val)
            local new_type = type(new_val)
            if (old_type == "table" and new_type == "table") then
               merge_task[old_val] = new_val
            else
               left[new_key] = new_val
            end
         end
      end
      merge_task[left] = nil
      left = next(merge_task)
   end
end
于 2012-12-17T16:29:54.487 回答
1

就像 Doug Currie 说的,你可以使用他的功能,但是他的方法有问题。如果first_table它的k索引中有东西,该函数将覆盖它。

我假设您正在尝试合并这些表,而不是覆盖索引和值。所以这将是我的方法,它非常相似,但用于合并表。

for _, v in pairs(second_table) do table.insert(first_table, v) end

此解决方案的唯一问题是索引设置为数字,而不是字符串。这适用于以数字作为索引的表,对于以字符串作为索引的表,使用 Doug Currie 的方法。

道格·柯里的方法:

for k,v in pairs(second_table) do first_table[k] = v end
于 2021-01-06T17:25:24.930 回答
0
for k,v in pairs(t2) do t1[k] = v end

字符串解决方案的关键

于 2015-11-05T10:10:56.497 回答