关联数组按值排序

3
我有以下代码,应该根据其“pos”值返回一个排序后的数组。
local tables = {}

table.insert(tables,{ ['pos']=2, ['name'] = 'C' })
table.insert(tables, {['pos']=1, ['name'] = 'A' })
table.insert(tables,{ ['pos']=30, ['name'] = 'D'} )


function comp(w1,w2)
    if tonumber(w1['pos']) > tonumber(w2['pos']) then
        return true
    end
end

table.sort(tables, comp)

for key,val in pairs(tables) do
    print(val['name'])
end

结果是:

D C A

期望的结果(按“pos”字母顺序排序):

A, C, D

有什么问题吗?

1个回答

4

PILtable.sort(table [, comp])的文档中得知:

[comp] 这个排序函数接收两个参数,必须返回true,如果第一个参数应该在排序后的数组中排在第一位。

因此,将函数更改为:

function comp(w1,w2)
    return w1['pos'] < w2['pos']
end

注意,这里的tonumberif都是不必要的。

正如@lhf指出的那样,这还可以更简单:

table.sort(tables, function(w1, w2) return w1.pos < w2.pos end)

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接