LUA string库详解
1. string库中所有的字符索引从前往后是1,2,...;从后往前是-1,-2,... ? string.byte(string [,pos]):返回第pos个字符的整数表示形式.如a为97. string.char(i1,i2...):i1,i2为整型,将i1,i2..等转化为对应的字符然后连接成字符串,并返回.如i1=97则返回a. string.dump(functoin):返回一个参数函数的2进制代码.(疑问) string.find(s,pattern [,init [,plain]]):查找pattern在s中的位置,返回pattern在s中的开始位置和结束位置.init是开始查找的位置.plain未知. string.len(s):返回字符串的长度. string.lower(s):变小写. string.upper(s):变大写. string.rep(s,n):将s拷贝n份,并连接起来,返回. string.sub(s,i [,j]):取s中从i开始到j为止的自字符串.默认j为长度.-i表示倒数. 例如: s = "[abc]" string.rep("abc",2) <==返回"abcabc" 例如: 第1个参数:源字符串 第2个参数:待替换之模式串 第3个参数:替换为reps 将s中所有符合pattern的字串替换为reps,返回结果串+匹配数 print(string.gsub("hello,world","o","a")) ????? <== hella,warld??????? 2 gsub也可以用拷贝捕获技巧 print(string.gsub("hello,"(o)","%1-%1")) <== hello-o,wo-orld??? 2 print(string.gsub("hello Lua","(.)(.)","%2%1")) <== ehll ouLa?????????? 4 function trim (s) return (string.gsub(s,"^%s*(.-)%s*$","%1")) end <== 注意匹配数用括号丢弃 string.gsub(s,func) 第3个参数:自定义函数,对找到的匹配操作,并传出替换值 s,n = string.gsub("hello world","l+",function(s) return "xxx" end) print(s,n) <== hexxxo worxxxd 2 string.gfind(s,pattern) 返回一个迭代器,迭代器每执行一次,返回下一个匹配串; iter = string.gfind("a=b c=d","[^%s+]=[^%s+]") print(iter()) <== a=b print(iter()) <== c=d 通常用于泛性for循环,下面的例子结果同上 for s in string.gfind("a=b c=d","[^%s+]=[^%s+]") do print(s) end 简单的模式串 s = "hello world" i,j = string.find(s,"hello") print(i,j) --> 1 5 print(string.sub(s,i,j)) --> hello print(string.find(s,"world")) --> 7 11 i,"l") print(i,j) --> 3 3 print(string.find(s,"lll")) --> nil 格式化的模式串 s = "Deadline is 30/05/1999,firm" date = "%d%d/%d%d/%d%d%d%d" print(string.sub(s,string.find(s,date))) --> 30/05/1999 下面的表列出了Lua支持的所有字符类: . 任意字符 %s 空白符 %p 标点字符 %c 控制字符 %d 数字 %x 十六进制数字 %z 代表0的字符 %a 字母 %l 小写字母 %u 大写字母 %w 字母和数字 上面字符类的大写形式表示小写所代表的集合的补集。例如,'%A'非字母的字符: 模式串中的特殊字符 ( ) . % + - * ? [ ^ $ '%' 用作特殊字符的转义字符 '%.' 匹配点; '%%' 匹配字符 '%'。 转义字符 '%'不仅可以用来转义特殊字符,还可以用于所有的非字母的字符。当对一个字符有疑问的时候,为安全起见请使用转义字符转义他。 用'[]'创建字符集 '[%w_]' 匹配字母数字和下划线 '[01]' 匹配二进制数字 '[%[%]]'匹配一对方括号 在'[]'中使用连字符'-' '%d'??? 表示 '[0-9]'; '%x'??? 表示 '[0-9a-fA-F]' '[0-7]' 表示 '[01234567]' 在'[]'开始处使用 '^' 表示其补集: '[^0-7]' 匹配任何不是八进制数字的字符; '[^/n]' 匹配任何非换行符户的字符。 '[^%s]' == '%S' 模式修饰符 + 匹配前一字符1次或多次 * 匹配前一字符0次或多次;最长匹配 - 匹配前一字符0次或多次;最短匹配 ? 匹配前一字符0次或1次 ^ 匹配字符串开头 $ 匹配字符串结尾 捕获:用()将要捕获的部分包围起来 pair = "name = Anna" firstidx,lastidx,key,value = string.find(pair,"(%a+)%s*=%s*(%a+)") print(key,value) <== name Anna 拷贝捕获(%1-%9) s = "abc /"it/'s a cat/"" _,_,q = string.find(s,"([/"'])(.-)%1")) print(q) <== it's a cat 如果%d代表第几个捕获的拷贝。 原文地址:http://blog.csdn.net/nmn0317/article/details/4933207 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |