现在先重点学习简单的语法和常用的函数库。
string 和table 。
1.table用法:
关系表类型,这是一个很强大的类型。我们可以把这个类型看作是一个数组。只是C语言的数组,只能用正整数来作索引;在Lua中,你可以用任意类型来作数组的索引,除了nil。同样,在C语言中,数组的内容只允许一种类型;在Lua中,你也可以用任意类型的值来作数组的内容,除了nil。 Table的定义很简单,它的主要特征是用"{"和"}"来括起一系列数据元素的。比如: T1 = {} -- 定义一个空表 T1[1]=10 -- 然后我们就可以象C语言一样来使用它了。 T1["John"]={Age=27, Gender="Male"} 这一句相当于: T1["John"]={} -- 必须先定义成一个表,还记得未定义的变量是nil类型吗 T1["John"]["Age"]=27 T1["John"]["Gender"]="Male" 当表的索引是字符串的时候,我们可以简写成: T1.John={} T1.John.Age=27 T1.John.Gender="Male" 或 T1.John{Age=27, Gender="Male"} 这是一个很强的特性。 在定义表的时候,我们可以把所有的数据内容一起写在"{"和"}"之间,这样子是非常方便,而且很好看。比如,前面的T1的定义,我们可以这么写:
T1=
{
10, -- 相当于 [1] = 10
[100] = 40,
John= -- 如果你原意,你还可以写成:["John"] =
{
Age=27, -- 如果你原意,你还可以写成:["Age"] =27
Gender=Male -- 如果你原意,你还可以写成:["Gender"] =Male
},
20 -- 相当于 [2] = 20
}
看起来很漂亮,不是吗?我们在写的时候,需要注意三点: 第一,所有元素之间,总是用逗号","隔开; 第二,所有索引值都需要用"["和"]"括起来;如果是字符串,还可以去掉引号和中括号; 第三,如果不写索引,则索引就会被认为是数字,并按顺序自动从1往后编;
eg:a={x=10,y=20,string="hero",123}
table 从1 开始计数。
---注意区分两种情况:有无“=”。没有则KEY=1.2.3(当一般数组使用,做记录)。。 有则是左边的变量作为KEY(做列表)。 如果单单是一个数字的话,如上例的123,那么 a[1]=123 ,不能写作a.1
----假如还有一个字符串出现在123前面,如“xxx”,那么a[1]=xxx.
----即第一个出现数字或者字符串(双引号)的地方就是a[1];
b.x=10。即以等号左边的为KEY ,右边是值。
-----必须记住:a.x==a["x"] 不等于 a[x]
2.for循环。泛型for。----注意: 循环变量是循环体的局部变量,绝不应该对循环变量作任何赋值。
迭代器 :所谓迭代器就是一种可以遍历一种集合中所有元素的机制。 ipairs -----迭代数组元素(只针对数字)
pairs-----迭代table中所有的元素
io.lines----迭代文件中的每行
string.gmatch-----迭代字符串中的单词
3.函数的使用
---注意多重返回值的用法,若一个函数调用的是最后的(或者仅有的)一个表达式,那么LUA会保留其尽可能多的返回值。
函数中的变量默认为局部变量。
4.字符串库
--lua中的字符串是不可变的。
string.upper(s): 把字符串中的小写字母转换为大写字母
string.lower(s): 把字符串中的大写字母转换为小写字母
string.rep(s,n):返回字符串s重复n次的结果
在Lua中,字符串的第一个索引是 1 。 索引-1 代表字符串的最后一个字符,-2表示倒数第二个字符
string.char(n):将多个整数转换为对应的字符;
string.byte(s):将字符串转换为对应的数字。
string.format():用于格式化字符串 。eg:string.format("pi=%.4f",math.pi)---pi=3.1416
4.2模式匹配(pattern-mathing 函数):这几个要注意区分!!
字符串库中最强大的函数是find,match,gsub(global substitution 全局替换),gmatch (global match 全局匹配),他们都是基于模式的。
string.find():用于在一个给定的目标字符串中搜索一个模式。最简单的一个模式的就是单词,它只会匹配与自己完全相同的拷贝。 当找到时,他会返回:匹配到的起始索引和结尾索引。如果没有则返回Nil 。eg : s="hello world" i,j=string.fing(s,"hello") --- 1 5 ; string.sub(s,i,j)---hello 。。find 第三个参数表示从此位置开始
string.match:
string.gsub(): 有3个参数: 目标字符串,模式和替换字符串。它的基本用法是将目标字符串中所有出现模式的地方替换成为替换字符串(注意顺序!!)第四个可选参数,可以限制替换的次数。 eg: s=string.gsub("all lli","l","x") ---- s=axx xxi 注意与string.sub 区别!!! gsub会有第二个返回结果:替换的次数。
string.gmatch() :会返回一个函数,通过该函数可以遍历到一个字符串中所有出现指定模式的地方。 实例: words={ } ; for w in string.gmatch(s,"%a+") do words[#words+1]=w end ”%a+“ 表示匹配一个或多个字母字符的序列(单词),本例中for循环会遍历目标字符串s中的所有单词,并且将他们存储到列表words中。
5.模式
5.1字符分类: %a ==字母; %c==控制字符; %d==数字;%l==小写字母;%u==大写字母;%p==标点符号;%s==空白字符;%w==字母和数字字符;%x==16进制数;%z==内部表示为0 的字符。 ---这些分类的大写可以表示它们的补集。
5.2魔法字符: ( ) . % + - * ? [ ] ^ $
字符%作为这些魔法字符的转义符。
5.3修饰符: + :重复1次或者多次 ;
* :重复0次或者多次 ; eg: 匹配像"()"或者 "( )"这样的一对空圆括号,可以使用模式“%(%s*%)”。 %s* 表示0个或者多个空格。
- :跟*一样,区别在于匹配最短的子串 ;
?:可选部分(出现0次或者1次)。
"[+-]?%d+"表示在一段文本当中查找整数,而这个整数可以包括一个可选的正负号。"[+-]"是一个匹配'+'和'-'的字符分类。后面的'?'说明这个符号是可选的。
如果一个模式以 ^ 开头,则表示它只会匹配目标字符串的开头部分。$结尾,则表示匹配结尾部分
》》eg "^%d" 表示 检查是否以数字开头。
" %b "匹配成对的字符。一般写作:%d<x><y>。
" [ ] "在一对方括号内将不同的字符分类或者单个字符组合起来。即可创建出属于用户自己的字符分类。
,需要捕获的部分写到一对圆括号内。对于具有捕获的模式,string.match函数(find 函数也可以)会将所有捕获到的值作为单独的结果返回!!eg: pair="name =anna" key,value=string.match(pair, "(%a+)%s*=%s*(%a+)") print(key,value)--->name anna ------注意,要匹配的模式中,有几个括号就返回几个值!!!! 括号里面的模式即要返回的内容。
7替换:string.gsub函数的第三个参数不仅是一个字符串,还可以使一个函数或者table。当用一个函数来调用时,string.gsub会在每次找到匹配时调用该函数,调用时的参数就是捕获到的内容,而该函数的返回值则作为要替换的字符串;;当用一个table来调用时,string.gsub会每次将捕获到的值作为key,在table中进行查找,并将对应的value作为要替换的字符串。
8.I/O库
9.操作系统库:定义在tabel os 中,其中包含了文件操作函数,获取当前日期和时间的函数。