一部分的table函数只对其数组部分产生影响,而另一部分则对整个table均产生影响. 下面会分开说明.?
table.concat(table,sep,? start,end)
concat是concatenate(连锁,连接)的缩写. table.concat()函数列出参数中指定table的数组部分从start位置到end位置的所有元素,元素间以指定的分隔符(sep)隔开。除了table外,其他的参数都不是必须的,分隔符的默认值是空字符,start的默认值是1,end的默认值是数组部分的总长.
sep,start,end这三个参数是顺序读入的,所以虽然它们都不是必须参数,但如果要指定靠后的参数,必须同时指定前面的参数.
[cpp]
view plain
copy
print
?
- tbl?=?{"alpha",?"beta",?"gamma"}??
- print(table.concat(tbl,?":"))??
- print(table.concat(tbl,?nil,?1,?2))??
- print(table.concat(tbl,?"n",?2,?3))??
tbl = {"alpha","beta","gamma"}
print(table.concat(tbl,":"))
print(table.concat(tbl,nil,1,2))
print(table.concat(tbl,"n",2,3))
alpha:beta:gamma
alphabeta
beta
gamma
table.insert(table,pos,value)
table.insert()函数在table的数组部分指定位置(pos)插入值为value的一个元素. pos参数可选,默认为数组部分末尾.
[cpp]
view plain
copy
print
?
- tbl?=?{"alpha",?"gamma"}??
- table.insert(tbl,?"delta")??
- table.insert(tbl,?"epsilon")??
- table.insert(tbl,?3,?"zeta")??
- print(table.concat(tbl,","))??
tbl = {"alpha","gamma"}
table.insert(tbl,"delta")
table.insert(tbl,"epsilon")
table.insert(tbl,3,"zeta")
print(table.concat(tbl,","))
alpha,beta,zeta,gamma,delta,epsilon
table.maxn(table)
table.maxn()函数返回指定table中所有正数key值中最大的key值. 如果不存在key值为正数的元素,则返回0. 此函数不限于table的数组部分.
[cpp]
view plain
copy
print
?
- tbl?=?{[1]?=?"a",?[2]?=?"b",?[3]?=?"c",?[26]?=?"z"}??
- print(#tbl)??
- print(table.maxn(tbl))??
- tbl[91.32]?=?true??
- print(table.maxn(tbl))??
tbl = {[1] = "a",[2] = "b",[3] = "c",[26] = "z"}
print(#tbl)
print(table.maxn(tbl))
tbl[91.32] = true
print(table.maxn(tbl))
3? --因为数组不连续
26
91.32
table.remove(table,pos)
table.remove()函数删除并返回table数组部分位于pos位置的元素. 其后的元素会被前移. pos参数可选,默认为table长度,即从最后一个元素删起.
[cpp]
view plain
copy
print
?
- tbl?=?{[1]?=?"a",?[26]?=?"z"}??
- table.remove(tbl)??
- print(table.concat(tbl,"))??
- table.remove(tbl,3)??
- print(table.concat(tbl,"))??
tbl = {[1] = "a",[26] = "z"}
table.remove(tbl)
print(table.concat(tbl,"))
table.remove(tbl,3)
print(table.concat(tbl,"))
a,b
a,b
table.sort(table,comp)
table.sort()函数对给定的table进行升序排序.
comp是一个可选的参数,此参数是一个外部函数,可以用来自定义sort函数的排序标准.
此函数应满足以下条件: 接受两个参数(依次为a,b),并返回一个布尔型的值,当a应该排在b前面时,返回true,反之返回false.
?
[cpp]
view plain
copy
print
?
- function?sortAsc(a,?b)??
- ????return?a?>?b??
- end??
- tbl?=?{"alpha",?"gamma",?"delta"}??
- tblNum?=?{1,5,7,9,4,6,8,10}??
- table.sort(tbl)??
- table.sort(tblNum)??
- print(table.concat(tbl,?",?"))??
- print(table.concat(tblNum,?"))??
- table.sort(tblNum,?sortAsc)??
- print(table.concat(tblNum,?"))??
function sortAsc(a,b)
return a > b
end
tbl = {"alpha","gamma","delta"}
tblNum = {1,10}
table.sort(tbl)
table.sort(tblNum)
print(table.concat(tbl,"))
print(table.concat(tblNum,"))
table.sort(tblNum,sortAsc)
print(table.concat(tblNum,"))
alpha,gamma
1,10
10,1
?
用类似的原理还可以写出更加复杂的排序函数. 例如,有一个table存有工会三名成员的姓名及等级信息:
guild = {}
table.insert(guild,{
name = "Cladhaire",
class = "Rogue",
level = 70,
})
table.insert(guild,{
name = "Sagart",
class = "Priest",{
name = "Mallaithe",
class = "Warlock",
level = 40,
})
对这个table进行排序时,应用以下的规则: 按等级升序排序,在等级相同时,按姓名升序排序.
可以写出这样的排序函数:
function sortLevelNameAsc(a,b)
if a.level == b.level then
return a.name < b.name
else
return a.level < b.level
end
end
测试功能如下:
> table.sort(guild,sortLevelNameAsc)
> for idx,value in ipairs(guild) do print(idx,value.name) end
1,Mallaithe
2,Cladhaire
3,Sagart
table.foreachi(table,function(i,v))
会期望一个从 1(数字 1)开始的连续整数范围,遍历table中的key和value逐对进行function(i,v)操作
[cpp]
view plain
copy
print
?
- t1?=?{2,?4,?6,?language="Lua",?version="5",?8,?10,?12,?web="hello?lua"};??
- table.foreachi(t1,?function(i,?v)?print?(i,?v)?end)?;?--等价于foreachi(t1,?print)??
t1 = {2,language="Lua",version="5",10,12,web="hello lua"};
table.foreachi(t1,v) print (i,v) end) ; --等价于foreachi(t1,print)
输出结果:
1?2
2?4
3?6
4?8
5?10
6?12
table.foreach(table,v))
与foreachi不同的是,foreach会对整个表进行迭代
[cpp]
view plain
copy
print
?
- t1?=?{2,?web="hello?lua"};??
- table.foreach(t1,?v)?end)?;??
t1 = {2,web="hello lua"};
table.foreach(t1,v) end) ;
输出结果:
1?2
2?4
3?6
4?8
5?10
6?12
web?hello lua
language?Lua
version?5
table.getn(table)
返回table中元素的个数
t1 = {1,5};
print(getn(t1))
->4
table.setn(table,nSize) 设置table中的元素个数