概述
lua中的正则表达式的归纳总结
%a 字母(a,b,...)
%d 数字(1, 2, ...)
%w 字母+数字
%s 空白
%c 控制符(n)
%x 十六进制
%u 大写字母
%l 小写字母
%p 标点
%z 代表0的字符
lua中的特殊字符
%: 用作特殊字符的转义字符 以及非字母的字符。 eg. %.-->匹配点号 %%-->匹配百分号
% + 非字母非数字字符,用来处理有功能的字符(^$()%.[]*+-?)
[多个字符] 括号里面有多个匹配字符 eg. [%w_]-->与 数字/字母或下划线匹配
[^多个字符] 与除了括号中的字符匹配 eg. [^%s] -->与所有非空格的字符匹配
% + 大写字符 --> 与除了该类字符匹配 eg. %A -->与所有非字母匹配
模式匹配函数
在string库中功能最强大的函数是:
*string.find(字符串查找)
string.gsub(全局字符串替换)
string.gfind(全局字符串查找)
string.gmatch(返回查找到字符串的迭代器)*
1、string.find(str, pattern, init, plain)
string.find的基本应用就是用来在目标串(subject string)内搜索匹配指定的模式的串。函数如果找到匹配的串返回他的位置,否则返回nil.最简单的模式就是一个单词,仅仅匹配单词本身。比如,模式’hello’仅仅匹配目标串中的”hello”。当查找到模式的时候,函数返回两个值:匹配串开始索引和结束索引。
s = "hello world"
string.find(s, "hello") --> 1 5
string.find(s, "world") --> 7 11
string.find(s, "l") --> 3 3
string.find(s, "lll") --> nil
string.find函数第三个参数是可选的:标示目标串中搜索的起始位置。当我们想查找目标串中所有匹配的子串的时候,这个选项非常有用。我们可以不断的循环搜索,每一次从前一次匹配的结束位置开始。下面看一个例子,下面的代码用一个字符串中所有的新行构造一个表:
local t = {} -- 存放回车符的位置
local i = 0
while true do
i = string.find(s, "n", i+1) -- 查找下一行
if i == nil then break end
table.insert(t, i)
end
local s = 'hello world from lua'
-- [[返回匹配字符串的起始位置和结束位置]]
print(string.find(s, "world"))
--result: 7 11
2、string.gsub(str, pattern, repl, n)
string.gsub()函数根据给定的配对表达式对源字符串str进行配对, 同时返回源字符串的一个副本, 该副本中成功配对的所有子字符串都将被替换. 函数还将返回成功配对的次数.实际的替换行为由repl参数的类型决定:
当repl为字符串时, 所有成功配对的子字符串均会被替换成指定的repl字串.
当repl为table时, 对每个成功配对的子字符串, 函数均会试图寻找以其为key值的table中的元素, 并返回该元素. 如果该配对包含任何捕获信息, 则以编号为1号的捕获作为key值进行查找.
当repl为函数时, 每个成功配对的子字符串均会作为参数被传入到该函数中去.
在repl是table或函数时, 如果该table或函数返回了字串或数字的值, 这个值依然会被用于替换副本字串中的配对子字串. 如果该table/函数返回的值为空, 将不发生替换.
n参数可选, 当它被指定时, string.gsub()函数只对源字符串中的前n个成功配对的成员进行操作.
以下是几个例子:
> print(string.gsub("hello world", "(%w+)", "%1 %1"))
hello hello world world 2
> print(string.gsub("hello Lua", "(%w+)%s*(%w+)", "%2 %1"))
Lua hello 1
> string.gsub("hello world", "%w+", print)
hello world 2
> lookupTable = {["hello"] = "hola", ["world"] = "mundo"}
> print(string.gsub("hello world", "(%w+)", lookupTable))
hola mundo 2
3、string.match(str, pattern, init)
string.match()只寻找源字串str中的第一个配对. 参数init可选, 指定搜寻过程的起点, 默认为1.
在成功配对时, 函数将返回配对表达式中的所有捕获结果; 如果没有设置捕获标记, 则返回整个配对字符串. 当没有成功的配对时, 返回nil.
string.match("abcdaef", "a")
-> a
4、string.reverse(str)
返回一个字符串的倒序排列
string.reverse("abcde")
->edcba
5、string.dump(function)
返回指定函数的二进制代码(函数必须是一个Lua函数,并且没有上值)
print(string.dump(function() print("a") end))
--[[result:
u?R
>>@A@@?printa@testLua2.lua>>>>_ENV]]
6、string.sub(str,sPos,ePos)
string.gsub的功能是截取字符串,他从指定起始位置截取一个字符串。string.sub可以利用string.find返回的值截取匹配的子串。
对简单模式而言,匹配的就是其本身
s = "hello world"
local i, j = string.find(s, "hello") --> 1 5
string.sub(s, i, j) --> hello
7、Lua中的特殊字符如下:
( ) . % + - ? [ ^ $*
‘%’ 用作特殊字符的转义字符,因此 ‘%.’ 匹配点;’%%’ 匹配字符 ‘%’。转义字符 ‘%’不仅可以用来转义特殊字符,还可以用于所有的非字母的字符。当对一个字符有疑问的时候,为安全起见请使用转义字符转义他。
*+ 匹配前一字符1次或多次
* 匹配前一字符0次或多次
- 匹配前一字符0次或多次
? 匹配前一字符0次或1次
‘+’,匹配一个或多个字符,总是进行最长的匹配。比如,模式串 ‘%a+’ 匹配一个或多个字母或者一个单词:*
print(string.gsub("one, and two; and three", "%a+", "word"))
--> word, word word; word word
‘%d+’ 匹配一个或多个数字(整数):
i, j = string.find("the number 1298 is even", "%d+")
print(i,j) --> 12 15
‘’ 与 ‘+’ 类似,但是他匹配一个字符0次或多次出现.一个典型的应用是匹配空白。比如,为了匹配一对圆括号()或者括号之间的空白,可以使用 ‘%(%s%)’。( ‘%s*’ 用来匹配0个或多个空白。由于圆括号在模式中有特殊的含义,所以我们必须使用 ‘%’ 转义他。)再看一个例子,’[%a][%w]*’ 匹配Lua程序中的标示符:字母或者下划线开头的字母下划线数字序列。
‘-’ 与 ‘’ 一样,都匹配一个字符的0次或多次出现,但是他进行的是最短匹配。某些时候这两个用起来没有区别,但有些时候结果将截然不同。比如,如果你使用模式 ‘[_%a][_%w]-’ 来查找标示符,你将只能找到第一个字母,因为 ‘[_%w]-’ 永远匹配空。另一方面,假定你想查找C程序中的注释,很多人可能使用 ‘/%.%/’(也就是说 “/” 后面跟着任意多个字符,然后跟着 “/” )。然而,由于 ‘.’ 进行的是最长匹配,这个模式将匹配程序中第一个 “/” 和最后一个 “*/” 之间所有部分:
test = "int x; /* x */ int y; /* y */"
print(string.gsub(test, "/%*.*%*/", "<COMMENT>"))
--> int x; <COMMENT>
然而模式 ‘.-’ 进行的是最短匹配,她会匹配 “/” 开始到第一个 “/” 之前的部分:
test = "int x; /* x */ int y; /* y */"
print(string.gsub(test, "/%*.-%*/", "<COMMENT>"))
--> int x; <COMMENT> int y; <COMMENT>
‘?’ 匹配一个字符0次或1次。举个例子,假定我们想在一段文本内查找一个整数,整数可能带有正负号。模式 ‘[+-]?%d+’ 符合我们的要求,它可以匹配像 “-12”、”23” 和 “+1009” 等数字。’[+-]’ 是一个匹配 ‘+’ 或者 ‘-’ 的字符类;接下来的 ‘?’ 意思是匹配前面的字符类0次或者1次。
与其他系统的模式不同的是,Lua中的修饰符不能用字符类;不能将模式分组然后使用修饰符作用这个分组。比如,没有一个模式可以匹配一个可选的单词(除非这个单词只有一个字母)。下面我将看到,通常你可以使用一些高级技术绕开这个限制。
以 ‘^’ 开头的模式只匹配目标串的开始部分,相似的,以 ‘$’ 结尾的模式只匹配目标串的结尾部分。这不仅可以用来限制你要查找的模式,还可以定位(anchor)模式。比如:
if string.find(s, "^%d") then ...
检查字符串s是否以数字开头,而
if string.find(s, "^[+-]?%d+$") then ...
检查字符串s是否是一个整数。
‘%b’ 用来匹配对称的字符。常写为 ‘%bxy’ ,x和y是任意两个不同的字符;x作为匹配的开始,y作为匹配的结束。比如,’%b()’ 匹配以 ‘(’ 开始,以 ‘)’ 结束的字符串:
print(string.gsub("a (enclosed (in) parentheses) line", "%b()", ""))
--> a line
常用的这种模式有:’%b()’ ,’%b[]’,’%b%{%}’ 和 ‘%b<>’。你也可以使用任何字符作为分隔符。
参考:http://www.cnblogs.com/whiteyun/archive/2009/09/02/1541043.html
最后
以上就是个性小兔子为你收集整理的lua 正则表达式的全部内容,希望文章能够帮你解决lua 正则表达式所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复