微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

lua table函数库

copy:http://www.voidcn.com/article/p-uojemdur-tb.html

Lua中的table函数库

一部分的table函数只对其数组部分产生影响,而另一部分则对整个table均产生影响. 下面会分开说明. 


table.concat(table,sep,  start,end)

concat是concatenate(连锁,连接)的缩写. table.concat()函数列出参数中指定table的数组部分从start位置到end位置的所有元素,元素间以指定的分隔符(sep)隔开。除了table外,其他的参数都不是必须的,分隔符的认值是空字符,start的认值是1,end的认值是数组部分的总长.

sep,start,end这三个参数是顺序读入的,所以虽然它们都不是必须参数,但如果要指定靠后的参数,必须同时指定前面的参数.

  1. tbl = {"alpha""beta""gamma"}  
  2. print(table.concat(tbl, ":"))  
  3. print(table.concat(tbl, nil, 1, 2))  
  4. print(table.concat(tbl, "\n", 2, 3))  

alpha:beta:gamma
alphabeta
beta
gamma

table.insert(table,pos,value)

table.insert()函数在table的数组部分指定位置(pos)插入值为value的一个元素. pos参数可选,认为数组部分末尾.

  1. tbl = {"alpha""gamma"}  
  2. table.insert(tbl, "delta")  
  3. table.insert(tbl, "epsilon")  
  4. table.insert(tbl, 3, "zeta")  
  5. print(table.concat(tbl,","))  


alpha,beta,zeta,gamma,delta,epsilon

table.maxn(table)

table.maxn()函数返回指定table中所有正数key值中最大的key值. 如果不存在key值为正数的元素,则返回0. 函数不限于table的数组部分.

  1. tbl = {[1] = "a", [2] = "b", [3] = "c", [26] = "z"}  
  2. print(#tbl)  
  3. print(table.maxn(tbl))  
  4. tbl[91.32] = true  
  5. print(table.maxn(tbl))  


3  --因为数组不连续
26
91.32


table.remove(table,pos)

table.remove()函数删除并返回table数组部分位于pos位置的元素. 其后的元素会被前移. pos参数可选,认为table长度,即从最后一个元素删起.

  1. tbl = {[1] = "a", [26] = "z"}  
  2. table.remove(tbl)  
  3. print(table.concat(tbl,"))  
  4. table.remove(tbl,3)  
  5. print(table.concat(tbl,"))  

a,b
a,b


table.sort(table,comp)

table.sort()函数对给定的table进行升序排序.

comp是一个可选的参数,此参数是一个外部函数,可以用来自定义sort函数的排序标准.

函数应满足以下条件: 接受两个参数(依次为a,b),并返回一个布尔型的值,当a应该排在b前面时,返回true,反之返回false.

 

  1. function sortAsc(a, b)  
  2.     return a > b  
  3. end  
  4. tbl = {"alpha""gamma""delta"}  
  5. tblNum = {1,5,7,9,4,6,8,10}  
  6. table.sort(tbl)  
  7. table.sort(tblNum)  
  8. print(table.concat(tbl, ", "))  
  9. print(table.concat(tblNum, "))  
  10. table.sort(tblNum, sortAsc)  
  11. 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)操作

  1. t1 = {2, 4, 6, language="Lua", version="5", 8, 10, 12, web="hello lua"};  
  2. table.foreachi(t1, function(i, 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会对整个表进行迭代

  1. t1 = {2, web="hello lua"};  
  2. 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中的元素个数

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐