濮阳杆衣贸易有限公司

主頁 > 知識庫 > LUA string庫使用小結

LUA string庫使用小結

熱門標簽:怎么去除地圖標注 百度地圖標注早餐區(qū)域 新岸線智能電銷機器人 漳州智云呼電話機器人 地圖標注大廈 清朝地圖標注哈爾濱 個人怎么在地圖標注需要的店鋪 冀州市地圖標注 武漢外呼防封系統(tǒng)多少錢

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

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

復制代碼 代碼如下:

s = "[abc]"
string.len(s)        ==返回5
string.rep("abc", 2) ==返回"abcabc"
string.lower("ABC") ==返回"abc"
string.upper("abc") ==返回"ABC"
string.sub(s, 2)     ==返回"abc]"
string.sub(s, -2)    ==返回"c]"
string.sub(s, 2, -2) ==返回"abc"
string.format(fmt, ...)返回一個類似printf的格式化字符串
string.find(s, pattern, pos)

第1個參數(shù):源字符串
第2個參數(shù):待搜索之模式串
第3個參數(shù):A hint, 從pos位置開始搜索

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

簡單的模式串:

復制代碼 代碼如下:

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, j = string.find(s, "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 數(shù)字
%x 十六進制數(shù)字
%z 代表0的字符
%a 字母
%l 小寫字母
%u 大寫字母
%w 字母和數(shù)字

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

模式串中的特殊字符:

復制代碼 代碼如下:

( ) . % + - * ? [ ^ $
'%' 用作特殊字符的轉義字符
'%.' 匹配點;
'%%' 匹配字符 '%'。

轉義字符 '%'不僅可以用來轉義特殊字符,還可以用于所有的非字母的字符。當對一個字符有疑問的時候,為安全起見請使用轉義字符轉義他。

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

復制代碼 代碼如下:

'[%w_]' 匹配字母數(shù)字和下劃線
'[01]' 匹配二進制數(shù)字
'[%[%]]'匹配一對方括號

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

復制代碼 代碼如下:

'%d'    表示 '[0-9]';
'%x'    表示 '[0-9a-fA-F]'
'[0-7]' 表示 '[01234567]'

在'[]'開始處使用 '^' 表示其補集:

復制代碼 代碼如下:

'[^0-7]' 匹配任何不是八進制數(shù)字的字符;
'[^\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代表第幾個捕獲的拷貝。
string.gsub(s, pattern, reps)

第1個參數(shù):源字符串
第2個參數(shù):待替換之模式串
第3個參數(shù):替換為reps

將s中所有符合pattern的字串替換為reps,返回結果串+匹配數(shù):

復制代碼 代碼如下:

print(string.gsub("hello, world", "o", "a"))       == hella, warld        2

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 == 注意匹配數(shù)用括號丟棄
string.gsub(s, pattern, func)

第3個參數(shù):自定義函數(shù),對找到的匹配操作,并傳出替換值:

復制代碼 代碼如下:

s, n = string.gsub("hello world", "l+", function(s) return "xxx" end)
print(s, n) == hexxxo worxxxd 2
string.gfind(s, pattern)

返回一個迭代器,迭代器每執(zhí)行一次,返回下一個匹配串:

復制代碼 代碼如下:

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

您可能感興趣的文章:
  • Lua中string.len()使用指南
  • Lua中的string庫和強大的模式匹配學習筆記
  • Lua loadstring函數(shù)用法實例
  • Lua中的loadfile、dofile、loadstring、require用法實例
  • Lua字符串庫(string庫)學習筆記
  • Lua中的string庫(字符串函數(shù)庫)總結
  • Lua中實現(xiàn)StringBuffer功能
  • Lua中字符串(string)淺析
  • Lua中string.lower()使用指南

標簽:金昌 濰坊 臺灣 天門 儋州 德宏 宣城 天門

巨人網絡通訊聲明:本文標題《LUA string庫使用小結》,本文關鍵詞  LUA,string,庫,使用,小結,LUA,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《LUA string庫使用小結》相關的同類信息!
  • 本頁收集關于LUA string庫使用小結的相關信息資訊供網民參考!
  • 推薦文章
    东丰县| 罗源县| 长子县| 增城市| 平阴县| 潢川县| 黄梅县| 南平市| 东宁县| 临西县| 尚义县| 武定县| 凌海市| 个旧市| 丹东市| 玉溪市| 西和县| 绥棱县| 灵璧县| 隆安县| 赤水市| 长治市| 阳曲县| 松原市| 页游| 黄大仙区| 渭源县| 乃东县| 建始县| 佳木斯市| 竹北市| 青海省| 兴山县| 霍邱县| 九寨沟县| 潢川县| 灵寿县| 集贤县| 连江县| 弋阳县| 遂宁市|