精品一区二区三区影院在线午夜_天天躁日日躁狠狠躁AV麻豆_国产午夜福利短视频_中文字幕乱偷无码AV先锋蜜桃_久久精品一二区东京热_国产成人亚洲日韩欧美久久久,国产成人精品久久一区二区三区

在lua的string庫和正則表達式

一.前提要了解一下lua 的string幾個(gè)方法

1. string庫中所有的字符索引從前往后是1,2,...;從后往前是-1,-2,...

2. string庫中所有的function都不會(huì )直接操作字符串,而是返回一個(gè)結果

string.len(s):返回字符串的長(cháng)度.

string.lower(s):變小寫(xiě).

string.upper(s):變大寫(xiě).

string.rep(s,n):將s拷貝n份,并連接起來(lái),返回.

string.sub(s,i [,j]):取s中從i開(kāi)始到j(luò )為止的自字符串.默認j為長(cháng)度.-i表示倒數.

1.string.find(s, pattern, pos)

  第1個(gè)參數:源字符串

  第2個(gè)參數:待搜索之模式串

  第3個(gè)參數:A hint, 從pos位置開(kāi)始搜索

  找到匹配返回:匹配串開(kāi)始和結束的位置,否則返回nil

2.string.gsub(s, pattern, reps) string.gsub(s, pattern, func)

  第1個(gè)參數:源字符串

  第2個(gè)參數:待替換之模式串

  第3個(gè)參數:替換為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個(gè)參數:自定義函數,對找到的匹配操作,并傳出替換值

  s, n = string.gsub("hello world", "l+", function(s) return "xxx" end)----> l+一個(gè)或多個(gè)l ,所以替換了 ll 和 l 返回為2

  print(s, n) <== hexxxo worxxxd 2

3.string.gfind

返回一個(gè)迭代器,迭代器每執行一次,返回下一個(gè)匹配串;

iter = string.gfind("a=b c=d", "[^%s+]=[^%s+]")

print(iter()) <== a=b

print(iter()) <== c=d

通常用于泛性for循環(huán),下面的例子結果同上

for s in string.gfind("a=b c=d", "[^%s+]=[^%s+]") do

print(s)

end

4.下面的表列出了Lua支持的所有字符類(lèi)

. 任意字符

%a 字母

%c 控制字符

%d 數字

%l 小寫(xiě)字母

%p 標點(diǎn)字符

%s 空白符

%u 大寫(xiě)字母

%w 字母和數字

%x 十六進(jìn)制數字

%z 代表0的字符

上面字符類(lèi)的大寫(xiě)形式表示小寫(xiě)所代表的集合的補集。例如, '%A'非字母的字符:

模式串中的特殊字符

( ) . % + - * ? [ ^ $

'%' 用作特殊字符的轉義字符

'%.' 匹配點(diǎn);

'%%' 匹配字符 '%'。

轉義字符 '%'不僅可以用來(lái)轉義特殊字符,還可以用于所有的非字母的字符。當對一個(gè)字符有疑問(wèn)的時(shí)候,為安全起見(jiàn)請使用轉義字符轉義他。

用'[]'創(chuàng )建字符集

'[%w_]' 匹配字母數字和下劃線(xiàn)

'[01]' 匹配二進(jìn)制數字

'[%[%]]'匹配一對方括號

在'[]'中使用連字符'-'

'%d' 表示 '[0-9]';

'%x' 表示 '[0-9a-fA-F]'

'[0-7]' 表示 '[01234567]'

在'[]'開(kāi)始處使用 '^' 表示其補集:

'[^0-7]' 匹配任何不是八進(jìn)制數字的字符;

'[^\n]' 匹配任何非換行符戶(hù)的字符。

'[^%s]' == '%S'

模式修飾符

  + 匹配前一字符1次或多次

  * 匹配前一字符0次或多次;最長(cháng)匹配

  - 匹配前一字符0次或多次;最短匹配

  ? 匹配前一字符0次或1次

  ^ 匹配字符串開(kāi)頭

  $ 匹配字符串結尾

參考資料:

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

綦江县| 彩票| 陆川县| 南雄市| 祁门县| 宾阳县| 榆社县| 漳州市| 谢通门县| 灯塔市| 崇义县| 阿坝| 达尔| 乌拉特中旗| 海门市| 孙吴县| 梁平县| 霍州市| 福鼎市| 天津市| 鲁甸县| 弥勒县| 灵宝市| 峨眉山市| 五华县| 抚宁县| 南宁市| 普洱| 东兰县| 图们市| 肥城市| 大冶市| 怀宁县| 宜都市| 固始县| 上高县| 古丈县| 泊头市| 永吉县| 驻马店市| 西乌|