Lua中的table函数库
一部分的table函数只对其数组部分产生影响,而另一部分则对整个table均产生影响. 下面会分开说明.?
concat是concatenate(连锁,连接)的缩写. table.concat()函数列出参数中指定table的数组部分从start位置到end位置的所有元素,元素间以指定的分隔符(sep)隔开。除了table外,其他的参数都不是必须的,分隔符的默认值是空字符,start的默认值是1,end的默认值是数组部分的总长. sep,start,end这三个参数是顺序读入的,所以虽然它们都不是必须参数,但如果要指定靠后的参数,必须同时指定前面的参数. > tbl = {"alpha","beta","gamma"} table.insert()函数在table的数组部分指定位置(pos)插入值为value的一个元素. pos参数可选,默认为数组部分末尾. > tbl = {"alpha","gamma"}
table.maxn()函数返回指定table中所有正数key值中最大的key值. 如果不存在key值为正数的元素,则返回0. 此函数不限于table的数组部分,但对于key为其他类型则不适用 而#t只限于计算数组部分长度 > tbl = {[1] = "a",[2] = "b",[3] = "c",[26] = "z"}
table.remove()函数删除并返回table数组部分位于pos位置的元素. 其后的元素会被前移. pos参数可选,默认为table长度,即从最后一个元素删起.
table.sort()函数对给定的table进行升序排序. > tbl = {"alpha","gamma","delta"} comp是一个可选的参数,此参数是一个外部函数,可以用来自定义sort函数的排序标准. 此函数应满足以下条件: 接受两个参数(依次为a,b),并返回一个布尔型的值,当a应该排在b前面时,返回true,反之返回false. 例如,当我们需要降序排序时,可以这样写: > sortFunc = function(a,b) return b < a end 用类似的原理还可以写出更加复杂的排序函数. 例如,有一个table存有工会三名成员的姓名及等级信息: guild = {}
可以写出这样的排序函数: function sortLevelNameAsc(a,b) 测试功能如下: > 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)操作 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?2 2?4 3?6 4?8 5?10 6?12 table.foreach(table,v)) 与foreachi不同的是,foreach会对整个表进行迭代 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中的元素个数 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |