主頁(yè) > 知識(shí)庫(kù) > Lua教程(十四):字符串庫(kù)詳解

Lua教程(十四):字符串庫(kù)詳解

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

1. 基礎(chǔ)字符串函數(shù):

    字符串庫(kù)中有一些函數(shù)非常簡(jiǎn)單,如:

    1). string.len(s) 返回字符串s的長(zhǎng)度;
    2). string.rep(s,n) 返回字符串s重復(fù)n次的結(jié)果;
    3). string.lower(s) 返回s的副本,其中所有的大寫都被轉(zhuǎn)換為了小寫形式,其他字符不變;
    4). string.upper(s) 和lower相反,將小寫轉(zhuǎn)換為大寫;
    5). string.sub(s,i,j) 提取字符串s的第i個(gè)到第j個(gè)字符。Lua中,第一個(gè)字符的索引值為1,最后一個(gè)為-1,以此類推,如:
    print(string.sub("[hello world]",2,-2))      --輸出hello world
    6). string.format(s,...) 返回格式化后的字符串,其格式化規(guī)則等同于C語言中printf函數(shù),如:
    print(string.format("pi = %.4f",math.pi)) --輸出pi = 3.1416
    7). string.char(...) 參數(shù)為0到多個(gè)整數(shù),并將每個(gè)整數(shù)轉(zhuǎn)換為對(duì)應(yīng)的字符。然后返回一個(gè)由這些字符連接而成的字符串,如:
    print(string.char(97,98,99)) --輸出abc
    8). string.byte(s,i) 返回字符串s的第i個(gè)字符的Ascii值,如果沒有第二個(gè)參數(shù),缺省返回第一個(gè)字符的Ascii值。
 

復(fù)制代碼 代碼如下:

    print(string.byte("abc"))      --輸出97
    print(string.byte("abc",-1))  --輸出99
 

    由于字符串類型的變量都是不可變類型的變量,因此在所有和string相關(guān)的函數(shù)中,都無法改變參數(shù)中的字符串值,而是生成一個(gè)新值返回。

    2. 模式匹配函數(shù):

    Lua的字符串庫(kù)提供了一組強(qiáng)大的模式匹配函數(shù),如find、match、gsub和gmatch。

    1). string.find函數(shù):
    在目標(biāo)字符串中搜索一個(gè)模式,如果找到,則返回匹配的起始索引和結(jié)束索引,否則返回nil。如:

復(fù)制代碼 代碼如下:

 s = "hello world"
 i, j = string.find(s,"hello") 
 print(i, j)        --輸出1  5
 i, j = string.find(s,"l")
 print(i, j)        --輸出3  3
 print(string.find(s,"lll"))  --輸出nil

    string.find函數(shù)還有一個(gè)可選參數(shù),它是一個(gè)索引,用于告訴函數(shù)從目標(biāo)字符串的哪個(gè)位置開始搜索。主要用于搜索目標(biāo)字符串中所有匹配的子字符串,且每次搜索都從上一次找到的位置開始。如:

復(fù)制代碼 代碼如下:

local t = {}
local i = 0
while true do
    i = string.find(s,"\n",i+1)
    if i == nil then
        break
    end
    t[#t + 1] = i
end

2). string.match函數(shù):

    該函數(shù)返回目標(biāo)字符串中和模式字符串匹配的部分。如:

復(fù)制代碼 代碼如下:

 date = "Today is 2012-01-01"
 d = string.match(date,"%d+\-%d+\-%d+")
 print(d)  --輸出2012-01-01

    3). string.gsub函數(shù):

    該函數(shù)有3個(gè)參數(shù),目標(biāo)字符串、模式和替換字符串?;居梅ㄊ菍⒛繕?biāo)字符串中所有出現(xiàn)模式的地方替換為替換字符串。如:
 

復(fù)制代碼 代碼如下:

    print(string.gsub("Lua is cute","cute","great"))  --輸出Lua is great
 

    該函數(shù)還有可選的第4個(gè)參數(shù),即實(shí)際替換的次數(shù)。
 
復(fù)制代碼 代碼如下:

    print(string.gsub("all lii","l","x",1))  --輸出axl lii
    print(string.gsub("all lii","l","x",2))  --輸出axx lii
 

    函數(shù)string.gsub還有另一個(gè)結(jié)果,即實(shí)際替換的次數(shù)。
    count = select(2, string.gsub(str," "," "))  --輸出str中空格的數(shù)量

    4). string.gmatch函數(shù):

    返回一個(gè)函數(shù),通過這個(gè)返回的函數(shù)可以遍歷到一個(gè)字符串中所有出現(xiàn)指定模式的地方。如:
 

復(fù)制代碼 代碼如下:

 words = {}
s = "hello world"
for w in string.gmatch(s,"%a+") do
    print(w)
    words[#words + 1] = w
end
--輸出結(jié)果為:
--hello
--world
 

  3. 模式:

    下面的列表給出了Lua目前支持的模式元字符;

  這些元字符的大寫形式表示它們的補(bǔ)集,如%A,表示所有非字母字符。
 

復(fù)制代碼 代碼如下:

    print(string.gsub("hello, up-down!","%S","."))   --輸出hello..up.down. 4
 

    上例中的4表示替換的次數(shù)。
    除了上述元字符之外,Lua還提供了另外幾個(gè)關(guān)鍵字符。如:( ) . % + - * ? [ ] ^ $
    其中%表示轉(zhuǎn)義字符,如%.表示點(diǎn)(.),%%表示百分號(hào)(%)。
    方括號(hào)[]表示將不同的字符分類,即可創(chuàng)建出屬于自己的字符分類,如[%w_]表示匹配字符、數(shù)字和下劃線。

    橫線(-)表示連接一個(gè)范圍,比如[0-9A-Z]

    如果^字符在方括號(hào)內(nèi),如[^\n],表示除\n之外的所有字符,即表示方括號(hào)中的分類的補(bǔ)集。如果^不在方括號(hào)內(nèi),則表示以后面的字符開頭,$和它正好相反,表示以前面的字符結(jié)束。如:^Hello%d$,匹配的字符串可能為Hello1、Hello2等。

    在Lua中還提供了4種用來修飾模式中的重復(fù)部分,如:+(重復(fù)1次或多次)、*(重復(fù)0次或多次)、-(重復(fù)0次或多次)和?(出現(xiàn)0或1次)。如:
 

復(fù)制代碼 代碼如下:

    print(string.gsub("one, and two; and three","%a+","word")) --輸出word, word word; word word
    print(string.match("the number 1298 is even","%d+")) --輸出1298
 

    星號(hào)(*)和橫線(-)的主要差別是,星號(hào)總是試圖匹配更多的字符,而橫線則總是試圖匹配最少的字符。

    4. 捕獲(capture):

    捕獲功能可根據(jù)一個(gè)模式從目標(biāo)字符串中抽出匹配于該模式的內(nèi)容。在指定捕獲是,應(yīng)將模式中需要捕獲的部分寫到一對(duì)圓括號(hào)內(nèi)。對(duì)于具有捕獲的模式,函數(shù)string.match會(huì)將所有捕獲到的值作為單獨(dú)的結(jié)果返回。即它會(huì)將目標(biāo)字符串切成多個(gè)捕獲到的部分。如:
 

復(fù)制代碼 代碼如下:

 pair = "name = Anna"
key,value = string.match(pair,"(%a+)%s*=%s*(%a+)")
print(key,value)  --輸出name anna

date = "Today is 2012-01-02"
y,m,d = string.match(date,"(%d+)\-(%d+)\-(%d+)")
print(y,m,d)      --輸出2012    01      02
 

還可以對(duì)模式本身使用捕獲。即%1表示第一個(gè)捕獲,以此類推,%0表示整個(gè)匹配,如:

復(fù)制代碼 代碼如下:

 print(string.gsub("hello Lua","(.)(.)","%2%1"))  --將相鄰的兩個(gè)字符對(duì)調(diào),輸出為ehll ouLa
 print(string.gsub("hello Lua!","%a","%0-%0"))    --輸出為h-he-el-ll-lo-o L-Lu-ua-a!

  5. 替換:

    string.gsub函數(shù)的第三個(gè)參數(shù)不僅可以是字符串,也可以是函數(shù)或table,如果是函數(shù),string.gsub會(huì)在每次找到匹配時(shí)調(diào)用該函數(shù),調(diào)用時(shí)的參數(shù)就是捕獲到的內(nèi)容,而該函數(shù)的返回值則作為要替換的字符串。當(dāng)用一個(gè)table來調(diào)用時(shí),string.gsub會(huì)用每次捕獲到的內(nèi)容作為key,在table中查找,并將對(duì)應(yīng)的value作為要替換的字符串。如果table中不包含這個(gè)key,那么string.gsub不改變這個(gè)匹配。如:

復(fù)制代碼 代碼如下:

function expand(s)
    return (string.gsub(s,"$(%w+)",_G))
end

name = "Lua"; status = "great"
print(expand("$name is $status, isn't it?"))  --輸出 Lua is great, isn't it?
print(expand("$othername is $status, isn't it?"))  --輸出 $othername is great, isn't it?

function expand2(s)
    return (string.gsub(s,"$(%w+)",function(n) return tostring(_G[n]) end))
end

print(expand2("print = $print; a = $a")) --輸出 print = function: 002B77C0; a = nil

您可能感興趣的文章:
  • Lua教程(一):簡(jiǎn)介、優(yōu)勢(shì)和應(yīng)用場(chǎng)景介紹
  • Lua教程(二):基礎(chǔ)知識(shí)、類型與值介紹
  • Lua教程(三):表達(dá)式和語句
  • Lua教程(四):函數(shù)詳解
  • Lua教程(五):迭代器和泛型for
  • Lua教程(六):編譯執(zhí)行與錯(cuò)誤
  • Lua教程(七):數(shù)據(jù)結(jié)構(gòu)詳解
  • Lua教程(八):數(shù)據(jù)持久化
  • Lua教程(九):元表與元方法詳解
  • Lua教程(十): 全局變量和非全局的環(huán)境
  • Lua教程(十一):模塊與包詳解
  • Lua教程(十二):面向?qū)ο缶幊?/li>
  • Lua教程(十三):弱引用table

標(biāo)簽:濰坊 宣城 儋州 德宏 金昌 天門 臺(tái)灣 天門

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Lua教程(十四):字符串庫(kù)詳解》,本文關(guān)鍵詞  Lua,教程,十四,字符串,庫(kù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Lua教程(十四):字符串庫(kù)詳解》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Lua教程(十四):字符串庫(kù)詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章