lua table库
整理自:http://www.cnblogs.com/whiteyun/archive/2009/08/10/1543139.html
1.table.concat(table, sep, start, end)
concat是concatenate(连锁, 连接)的缩写. table.concat()函数列出参数中指定table的数组部分从start位置到end位置的所有元素, 元素间以指定的分隔符(sep)隔开。除了table外, 其他的参数都不是必须的, 分隔符的默认值是空字符, start的默认值是1, end的默认值是数组部分的总长.
sep, start, end这三个参数是顺序读入的, 所以虽然它们都不是必须参数, 但如果要指定靠后的参数,
必须同时指定前面的参数.
test = {"a","b","c","d"}
print(table.concat(test,"#"));
print(table.concat(test,"#",1,2));
输出结果:
a#b#c#d
a#b
2.table.insert(table, pos, value)
table.insert()函数在table的数组部分指定位置(pos)插入值为value的一个元素. pos参数可选,
默认为数组部分末尾.
3.table.remove(table, pos)
table.remove()函数删除并返回table数组部分位于pos位置的元素. 其后的元素会被前移. pos参数可选,
默认为table长度, 即从最后一个元素删起.
4.table.maxn(table)
table.maxn()函数返回指定table中所有正数key值中最大的key值. 如果不存在key值为正数的元素, 则返回0.
此函数不限于table的数组部分.
test = {[1] = 998, [2] = 998, [44] = 998}
print(#test);
print(table.maxn(test));
test[99.8] = 10086
print(table.maxn(test));
输出结果:
2
44
99.8
5.table.sort(table, comp)
table.sort()函数对给定的table进行升序排序.comp是一个可选的参数, 此参数是一个外部函数,
可以用来自定义sort函数的排序标准.
此函数应满足以下条件: 接受两个参数(依次为a, b), 并返回一个布尔型的值, 当a应该排在b前面时, 返回true,
反之返回false.
test = {4,55,2,77,9};
table.sort(test);
print(table.concat(test, " "));
t_sort = function(a,b) return a>b end;
table.sort(test, t_sort);
print(table.concat(test, " "));
输出结果:
2 4 9 55 77
77 55 9 4 2
6.table.foreachi(table, function(i, v))
会期望一个从 1(数字 1)开始的连续整数范围,遍历table中的key和value逐对进行function(i, v)操作
test = {9,8,66,77,8,a = "a", b = "b", c = "c"};
table.foreachi(test, function(key,value) print(key,value) end);
输出结果:
1 9
2 8
3 66
4 77
5 8
7.table.foreach(table, function(i, v))
与foreachi不同的是,foreach会对整个表进行迭代
test = {9,8,66,77,8,a = "a", b = "b", c = "c"};
table.foreach(test, function(key,value) print(key,value) end);
输出结果:
1 9
2 8
3 66
4 77
5 8
a a
c c
b b
8.table.getn(table)
返回table中元素的个数
最新文章
- Spring 4 使用Freemarker模板发送邮件&;添加附件
- MFC学习笔记(一)
- C# 配置文件 AppSettings和ConnectionStrings的区别
- Http压力测试工具HttpTest4Net
- iOS_UIImage_Gif的合成
- 参数化命令相关知识点之==================防止SQl的注入
- JSON与js对象序列化
- BZOJ 3665: maths
- DOM: 如何获取元素下的第一个子元素
- UVA11538 - Chess Queen(数学组合)
- gitHub入门指导
- 【转】Linux Page Cache的工作原理
- codeforces 675C C. Money Transfers(贪心)
- hdu 5432 Pyramid Split 二分
- easyui源码翻译1.32--SplitButton(分割按钮)
- Spark Streaming与kafka整合实践之WordCount
- jQuery 双击事件(dblclick)时,不触发单击事件(click)
- (网页)html中页面传递参数不用cookie不用缓存,js方法搞定
- multer详解
- python-反射、新式类与经典类搜索的优先级
热门文章
- Codeforces Round #369 (Div. 2) A. Bus to Udayland【字符串/二维字符数组求连起来的座位并改为其他字符】
- flow JavaScript 静态类型检查工具
- win7 下注册dll文件失败
- App Distribution Guide (二)
- JAVA常见算法题(二十四)
- 常用函数 __MySQL必知必会
- idea 转普通项目为maven 项目
- zabbix web监测
- 前端存储之indexedDB
- iOS小技巧 - 如何使UIView可以绑定点击事件