Lua中的table函数库

Lua中的table函数库,第1张

概述Lua中的table函数库

下面是内存溢出 jb51.cc 通过网络收集整理的代码片段。

内存溢出小编现在分享给大家,也给大家做个参考。

一部分的table函数只对其数组部分产生影响,而另一部分则对整个table均产生影响. 下面会分开说明. table.concat(table,sep,start,end)concat是concatenate(连锁,连接)的缩写. table.concat()函数列出参数中指定table的数组部分从start位置到end位置的所有元素,元素间以指定的分隔符(sep)隔开。除了table外,其他的参数都不是必须的,分隔符的默认值是空字符,start的默认值是1,end的默认值是数组部分的总长.sep,end这三个参数是顺序读入的,所以虽然它们都不是必须参数,但如果要指定靠后的参数,必须同时指定前面的参数.> tbl = {"Alpha","beta","gamma"}> print(table.concat(tbl,":"))Alpha:beta:gamma> print(table.concat(tbl,nil,1,2))Alphabeta> print(table.concat(tbl,"\n",2,3))betagammatable.insert(table,pos,value)table.insert()函数在table的数组部分指定位置(pos)插入值为value的一个元素. pos参数可选,默认为数组部分末尾.> tbl = {"Alpha","gamma"}> table.insert(tbl,"delta")> table.insert(tbl,"epsilon")> print(table.concat(tbl,",")Alpha,beta,gamma,delta,epsilon> table.insert(tbl,3,"zeta")> print(table.concat(tbl,zeta,epsilontable.maxn(table)table.maxn()函数返回指定table中所有正数key值中最大的key值. 如果不存在key值为正数的元素,则返回0. 此函数不限于table的数组部分.> tbl = {[1] = "a",[2] = "b",[3] = "c",[26] = "z"}> print(#tbl)3               -- 因为26和之前的数字不连续,所以不算在数组部分内> print(table.maxn(tbl))26> tbl[91.32] = true> print(table.maxn(tbl))91.32table.remove(table,pos)table.remove()函数删除并返回table数组部分位于pos位置的元素. 其后的元素会被前移. pos参数可选,默认为table长度,即从最后一个元素删起.table.sort(table,comp)table.sort()函数对给定的table进行升序排序.> tbl = {"Alpha","gamma","delta"}> table.sort(tbl)> print(table.concat(tbl,"))Alpha,gammacomp是一个可选的参数,此参数是一个外部函数,可以用来自定义sort函数的排序标准.此函数应满足以下条件: 接受两个参数(依次为a,b),并返回一个布尔型的值,当a应该排在b前面时,返回true,反之返回false.例如,当我们需要降序排序时,可以这样写:> sortFunc = function(a,b) return b < a end> table.sort(tbl,sortFunc)> print(table.concat(tbl,"))gamma,Alpha用类似的原理还可以写出更加复杂的排序函数. 例如,有一个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 endend测试功能如下:> table.sort(guild,sortLevelnameAsc)> for IDx,value in ipairs(guild) do print(IDx,value.name) end1,Mallaithe2,Cladhaire3,Sagarttable.foreachi(table,function(i,v))会期望一个从 1(数字 1)开始的连续整数范围,遍历table中的key和value逐对进行function(i,v) *** 作t1 = {2,4,6,language="Lua",version="5",8,10,12,web="hello lua"};table.foreachi(t1,v) print (i,v) end) ; --等价于foreachi(t1,print)输出结果:1 22 43 64 85 106 12table.foreach(table,v))与foreachi不同的是,foreach会对整个表进行迭代t1 = {2,web="hello lua"};table.foreach(t1,v) end) ;输出结果:1 22 43 64 85 106 12web hello lualanguage Luaversion 5table.getn(table)返回table中元素的个数t1 = {1,5};print(getn(t1))->4table.setn(table,nSize)设置table中的元素个数

以上是内存溢出(jb51.cc)为你收集整理的全部代码内容,希望文章能够帮你解决所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

总结

以上是内存溢出为你收集整理的Lua中的table函数库全部内容,希望文章能够帮你解决Lua中的table函数库所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1278318.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-09
下一篇 2022-06-09

发表评论

登录后才能评论

评论列表(0条)

保存