lua 支持的全部字符类:
. 任意字符
%s 空白符 空白字符通常包括空格、换行符\n、制表符\t以及回到行首符\r
%p 标点字符
%c 控制字符
%d 数字
%x 十六进制数字
%z 表明0的字符
%a 字母
%l 小写字母
%u 大写字母
%w 字母和数字
上面字符类的大写形式表示小写所表明的集合的补集。例如,'%A'非字母的字符:安全
模式修饰符
+ 匹配前一字符1次或屡次
* 匹配前一字符0次或屡次;最长匹配 -- 先尽量长地把本次匹配模式走完,再继续下一个模式,
- 匹配前一字符0次或屡次;最短匹配 -- 本次匹配模式每走一步,就考查下一个模式可否进入.
? 匹配前一字符0次或1次
^ 匹配字符串开头
$ 匹配字符串结尾lua
模式串中的特殊字符
( ) . % + - * ? [ ^ $
'%' 用做特殊字符的转义字符
'%.' 匹配点;
'%%' 匹配字符 '%'。
转义字符 '%'不只能够用来转义特殊字符,还能够用于全部的非字母的字符。当对一个字符有疑问的时候,为安全起见请使用转义字符转义他。spa
用'[]'建立字符集
'[%w_]' 匹配字母数字和下划线
'[01]' 匹配二进制数字
'[%[%]]' 匹配一对方括号code
在'[]' 中 使用连字符'-'
'%d' 表示 '[0-9]';
'%x' 表示 '[0-9a-fA-F]'
'[0-7]' 表示 '[01234567]'字符串
在'[]'开始处使用 '^' 表示其补集:
'[^0-7]' 匹配任何不是八进制数字的字符;
'[^\n]' 匹配任何非换行符户的字符。
'[^%s]' == '%S'input
捕获:用()将要捕获的部分包围起来:
pair = "name = Anna" firstidx, lastidx, key, value = string.find(pair, "(%a+)%s*=%s*(%a+)") print(key, value) <== name Anna 咱们也能够将捕获用于模式串自身,"([\"'])(.-)%1",这里的%1表示匹配第一个捕获的一份拷贝。
1. 匹配首尾空白符
string.gsub(input, "^[ \t\n\r]+", "")
空白字符通常包括空格、换行符\n、制表符\t以及回到行首符\r,固然若是有特殊需求须要将其余的字符也当作空白字符也都是能够的!string
string.gsub(input, "%s+$", "") %s 表明 空白符ast
string.gsub(input, "^%s*(.-)%s*$", "%1")class
return (string.gsub(input, "^%s*(.-)%s*$", "%1"))加一层括号,只返回格式化后的字符串!perl