一部分的table函数只对其数组部分产生影响, 而另一部分则对整个table均产生影响. 下面会分开说明.
table.concat(table, sep, start, end)
concat是concatenate(连锁, 连接)的缩写. table.concat()函数列出参数中指定table的数组部分从start位置到end位置的所有元素, 元素间以指定的分隔符(sep)隔开。除了table外, 其他的参数都不是必须的, 分隔符的默认值是空字符, start的默认值是1, end的默认值是数组部分的总长.
sep, start, 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)) beta gamma
table.insert(table, pos, value)
table.insert()函数在table的数组部分指定位置(pos)插入值为value的一个元素. pos参数可选, 默认为数组部分末尾.
> tbl = {"alpha", "beta", "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, ", ") alpha, beta, zeta, gamma, delta, epsilon
table.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.32
table.remove(table, pos)
table.remove()函数删除并返回table数组部分位于pos位置的元素. 其后的元素会被前移. pos参数可选, 默认为table长度, 即从最后一个元素删起.
table.sort(table, comp)
table.sort()函数对给定的table进行升序排序.
> tbl = {"alpha", "beta", "gamma", "delta"} > table.sort(tbl) > print(table.concat(tbl, ", ")) alpha, beta, delta, gamma
comp是一个可选的参数, 此参数是一个外部函数, 可以用来自定义sort函数的排序标准.
此函数应满足以下条件: 接受两个参数(依次为a, b), 并返回一个布尔型的值, 当a应该排在b前面时, 返回true, 反之返回false.
例如, 当我们需要降序排序时, 可以这样写:
> sortFunc = function(a, b) return b < a end > table.sort(tbl, sortFunc) > print(table.concat(tbl, ", ")) gamma, delta, beta, alpha
用类似的原理还可以写出更加复杂的排序函数. 例如, 有一个table存有工会三名成员的姓名及等级信息:
guild = {}table.insert(guild, { name = "Cladhaire", class = "Rogue", level = 70, })
table.insert(guild, { name = "Sagart", class = "Priest", level = 70, })
table.insert(guild, { 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, functhtml" target="_blank">ion(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, 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, function(i, v))
与foreachi不同的是,foreach会对整个表进行迭代
t1 = {2, 4, 6, language="Lua", version="5", 8, 10, 12, web="hello lua"}; table.foreach(t1, function(i, v) print (i, 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, 2, 3, 5}; print(getn(t1)) ->4
table.setn(table, nSize)
设置table中的元素个数
本文向大家介绍Lua中table的一些辅助函数介绍,包括了Lua中table的一些辅助函数介绍的使用技巧和注意事项,需要的朋友参考一下 table库是有一些辅助函数构成的,这些函数将table作为数组来操作。其中,有对列表中插入和删除元素的函数,有对数组元素进行排序的函数,还有对链接一个数组中所有字符串的函数。 0.table.getn()Lua 中我们经常假定 array 在最后一个非 nil
本文向大家介绍Lua字符串库中的几个重点函数介绍,包括了Lua字符串库中的几个重点函数介绍的使用技巧和注意事项,需要的朋友参考一下 在《Lua中的一些库》中也说到了,要对string库的模式匹配进行单独的讲解。对于字符串的处理,对于任何语言的学习来说,都是一个难点,而且也是一个必会的知识点。给你一个字符串,让你按照某种需求进行处理,你不会,那是多么尴尬的一件事情。所以,看完《Lua中的一些库》和这
本文向大家介绍Lua中获取table长度的方法,包括了Lua中获取table长度的方法的使用技巧和注意事项,需要的朋友参考一下 官方文档是这么描述#的: 取长度操作符写作一元操作 #。 字符串的长度是它的字节数(就是以一个字符一个字节计算的字符串长度)。 table t 的长度被定义成一个整数下标 n 。 它满足 t[n] 不是 nil 而 t[n+1] 为 nil; 此外,如果 t[1] 为 n
本文向大家介绍举例简介Lua中函数的基本用法,包括了举例简介Lua中函数的基本用法的使用技巧和注意事项,需要的朋友参考一下
本文向大家介绍Lua中os库详细介绍,包括了Lua中os库详细介绍的使用技巧和注意事项,需要的朋友参考一下 这个库通过表os实现 os.clock () 功能:返回一个程序使用CPU时间的一个近似值 例如: 输出: os.date ([format [, time]]) 功能:返回一个按format格式化日期、时间的字串或表 若设置time参数,则按time指定的时间格式化,否则按当前时间格式化
本文向大家介绍Lua table中安全移除元素的方法,包括了Lua table中安全移除元素的方法的使用技巧和注意事项,需要的朋友参考一下 在Lua中,table如何安全的移除元素这点挺重要,因为如果不小心,会没有正确的移除,造成内存泄漏。 引子 比如有些朋友常常这么做,大家看有啥问题 将test表中的偶数移除掉 打印结果: 有问题吧,20怎么还在?这就是在遍历中删除导致的。 如何做呢? Let'