一.前提要了解一下lua 的string幾個方法
1. string庫中所有的字符索引從前往后是1,2,...;從后往前是-1,-2,...
2. string庫中所有的function都不會直接操作字符串,而是返回一個結果
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表示倒數.
1.string.find(s, pattern, pos)
第1個參數:源字符串
第2個參數:待搜索之模式串
第3個參數:A hint, 從pos位置開始搜索
找到匹配返回:匹配串開始和結束的位置,否則返回nil
2.string.gsub(s, pattern, reps) string.gsub(s, pattern, func)
第1個參數:源字符串
第2個參數:待替換之模式串
第3個參數:替換為reps
返回 結果串+匹配數
gsub也可以用拷貝捕獲技巧
print(string.gsub("hello, world", "(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, pattern, func)
第3個參數:自定義函數,對找到的匹配操作,並傳出替換值
s, n = string.gsub("hello world", "l+", function(s) return "xxx" end)----> l+一個或多個l ,所以替換了 ll 和 l 返回為2
print(s, n) <== hexxxo worxxxd 2
3.string.gfind
返回一個迭代器,迭代器每執行一次,返回下一個匹配串;
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
4.下面的表列出了Lua支持的所有字符類
. 任意字符
%a 字母
%c 控制字符
%d 數字
%l 小寫字母
%p 標點字符
%s 空白符
%u 大寫字母
%w 字母和數字
%x 十六進制數字
%z 代表0的字符
上面字符類的大寫形式表示小寫所代表的集合的補集。例如, '%A'非字母的字符:
模式串中的特殊字符
( ) . % + - * ? [ ^ $
'%' 用作特殊字符的轉義字符
'%.' 匹配點;
'%%' 匹配字符 '%'。
轉義字符 '%'不僅可以用來轉義特殊字符,還可以用於所有的非字母的字符。當對一個字符有疑問的時候,為安全起見請使用轉義字符轉義他。
用'[]'創建字符集
'[%w_]' 匹配字母數字和下划線
'[01]' 匹配二進制數字
'[%[%]]'匹配一對方括號
在'[]'中使用連字符'-'
'%d' 表示 '[0-9]';
'%x' 表示 '[0-9a-fA-F]'
'[0-7]' 表示 '[01234567]'
在'[]'開始處使用 '^' 表示其補集:
'[^0-7]' 匹配任何不是八進制數字的字符;
'[^\n]' 匹配任何非換行符戶的字符。
'[^%s]' == '%S'
模式修飾符
+ 匹配前一字符1次或多次
* 匹配前一字符0次或多次;最長匹配
- 匹配前一字符0次或多次;最短匹配
? 匹配前一字符0次或1次
^ 匹配字符串開頭
$ 匹配字符串結尾
參考資料:
https://msdn.microsoft.com/zh-cn/library/ae5bf541(VS.80).aspx
http://blog.csdn.net/liuyukuan/article/details/5489623
http://www.cnblogs.com/light169/archive/2006/10/18/532347.html