【问题标题】:how to sort a table in lua?如何在lua中对表格进行排序?
【发布时间】:2014-08-01 13:56:50
【问题描述】:

我有一个包含 2 个关键数据的 lua 表。我想按“num1”列按升序对表格进行排序,或者如果不可能,则按键值按升序对表格进行排序

这是我目前所拥有的:

local widgets = {}
widgets[1568] = {}
widgets[1568]["num1"] = 99999
widgets[1568]["val2"] = "NA"
widgets[246] = {}
widgets[246]["num1"] = 90885
widgets[246]["val2"] = "NA"
widgets[250] = {}
widgets[250]["num1"] = 95689
widgets[250]["val2"] = "NA"
widgets[251] = {}
widgets[251]["num1"] = 95326
widgets[251]["val2"] = "NA"
widgets[252] = {}
widgets[252]["num1"] = 95301
widgets[252]["val2"] = "NA"
widgets[256] = {}
widgets[256]["num1"] = 95303
widgets[256]["val2"] = "NA"

-- ATTEMPT TO SORT
--table.sort(widgets, function(a,b) return tonumber(a.num1.value) < tonumber(b.num1.value) end)
--table.sort(widgets, function(a,b) return tonumber(a.num1) < tonumber(b.num1) end)

--TRY SORTING BY ID:
table.sort(widgets, function(a,b) return tonumber(a) < tonumber(b) end)

for i, v in pairs(widgets) do
    print(v.num1)
end

任何建议将不胜感激。现在,我正在查看Sort a Table[] in Lua 以尝试了解“spairs”功能。但这个例子略有不同,因为我在一个表中有一个表......

谢谢。

解决方案

根据下面的答案,我创建了一个新表并从旧表中逐一添加记录,使用表插入如下:

local new_widgets = {}
for i, v in pairs(widgets) do
    table.insert(new_widgets, id=v.id, num1= v.num1, num2 = v.num2)
end

然后我对 new_wigets 进行了排序。

【问题讨论】:

  • 您将无法为此使用table.sort,因为您的表中的索引不是从 1 开始并连续运行。在内部,table.sort 从 1 运行到 #table,因此它不会迭代小部件。您必须推出自己的排序功能并自己调用它。请参阅lua docs about table.sort 进行验证。您的函数必须使用 pairs 迭代表。

标签: sorting lua lua-table


【解决方案1】:

Lua 表是哈希表。他们的条目没有特定的顺序。

你可以通过使用连续的数字索引来伪造它,然后通过增加一个数字来迭代(注意:在内部 Lua 实际上会将它实现为一个数组,但这是一个实现细节;从概念上讲,表条目没有特定的顺序)。

t[2] = "two"
t[3] = "three"
t[1] = "one"

for i=1,#t do print(t[i]) end

ipairs 创建一个迭代器,它与这个 for 循环做同样的事情。

因此,如果您希望对数据进行排序,则需要将其放在具有连续数字索引的表中。

在您的情况下,您可以通过多种不同的方式进行操作。这是给猫剥皮的一种方法:

而不是这个:

local widgets = {
    [246] = { num1 = 90885, val2 = "NA" }
    [250] = { num1 = 95689, val2 = "NA" }
    [251] = { num1 = 95326, val2 = "NA" }
    [252] = { num1 = 95301, val2 = "NA" }
    [256] = { num1 = 95303, val2 = "NA" }
}

你想要这个:

local widgets = {
    { id = 246, num1 = 90885, val2 = "NA" },
    { id = 250, num1 = 95689, val2 = "NA" },
    { id = 251, num1 = 95326, val2 = "NA" },
    { id = 252, num1 = 95301, val2 = "NA" },
    { id = 256, num1 = 95303, val2 = "NA" },
}

-- sort ascending by num1
table.sort(widgets, function(a,b) return a.num1 < b.num1 end)

for i, widget in ipairs(widgets) do
    print(widget.num1)
end

如果您需要通过 id 快速查找小部件的能力,您可以为此创建一个查找表:

local widgetById = {}
for i,widget in pairs(widgets) do
    widgetById[widget.id] = widget
end

【讨论】:

  • 你能告诉我如何从原始表创建新表吗?我的原始表是我无法更改的数据库查询的结果集。
  • 我会试试table.insert
猜你喜欢
  • 2011-10-07
  • 2013-03-20
  • 2020-02-18
  • 2013-07-29
  • 1970-01-01
  • 2014-10-13
  • 2020-02-08
  • 1970-01-01
  • 2019-03-04
相关资源
最近更新 更多