按给定顺序从table [1]到table [n]对表元素进行排序,其中n是表的长度。comp是可选参数,这是一个排序函数,如果给定了的话,那排序将会按照排序函数里的规则进行排序。
此order函数接收两个参数,并且如果第一个参数应在排序数组中排在首位,则必须返回true。如果未提供此功能,则sort使用默认的小于运算(对应于'<'运算符)。
多条件优先级排序
当需要根据多个字段来决定排序结果时,可以这么设计一下排序函数:
举例,已知一个表list,里面有三个字段分别为 name id isKeyItem 接下来需要按照优先级 isKeyItem > id > name 进行排序
local list = {
{name="change", id=4, isKeyItem = false},
{name="jiumy", id=2, isKeyItem = false},
{name="uio", id=3, isKeyItem = true},
{name="tom", id=3, isKeyItem = true},
{name="tom", id=5, isKeyItem = false},
{name="feng", id=1, isKeyItem = false},
}
排序比较函数如下:
table.sort(list, function ( l, r )
if l.isKeyItem ~= r.isKeyItem then
return l.isKeyItem and not r.isKeyItem --isKeyItem为true的排在最前
end
if l.id ~= r.id then
return l.id < r.id --id小的放前面
end
if l.name ~= r.name then
return l.name < r.name --名称升序排列
end
return false
end)
最终排序结果如下:
name=tom id=3 isKeyItem=true
name=uio id=3 isKeyItem=true
name=feng id=1 isKeyItem=false
name=jiumy id=2 isKeyItem=false
name=change id=4 isKeyItem=false
name=tom id=5 isKeyItem=false
[Finished in 0.0s]