Lua解釋器對字符串的支持很有限。一個程序可以創(chuàng)建字符串并連接字符串,但不能截取子串,檢查字符串的大小,檢測字符串的內(nèi)容。在Lua中操縱字符串的功能基本來自于string庫。
--返回字符串s的長度
local s = "HelloWorld"
print(string.len(s)) -->10
--重復(fù)n次字符串s的串
print(string.rep(s,2)) -->HelloWorldHelloWorld
--大寫字母轉(zhuǎn)換成小寫
print(string.lower(s)) -->helloworld
--小寫轉(zhuǎn)換成大寫
print(string.upper(s)) -->HELLOWORLD
--截取字符串
local s = "[in brackets]"
print(string.sub(s,2,-1)) -->in brackets]
--將每一個數(shù)字轉(zhuǎn)換成字符
print(string.char(97)) -->a
--將每一個字符轉(zhuǎn)換成數(shù)字
print(string.byte("abc"))
print(string.byte("abc", 2)) --> 98
print(string.byte("abc", -1)) --> 99
--注:使用負(fù)數(shù)索引訪問字符串的最后一個字符
--對字符串進(jìn)行格式化輸出
PI = 3.14165120
print(string.format("pi = %.4f", PI)) -->pi = 3.1417
--注釋:使用和C語言的printf函數(shù)幾乎一模一樣,你完全可以照C語言的printf來使用這個函數(shù).
注:
string庫中所有的字符索引從前往后是1,2,...;從后往前是-1,-2,...
string庫中所有的function都不會直接操作字符串,而是返回一個結(jié)果。
在string庫中功能最強(qiáng)大的函數(shù)是:string.find(字符串查找),string.gsub(全局字符串替換),and string.gfind(全局字符串查找)。這些函數(shù)都是基于模式匹配的。
1.string.find
說明:用來在目標(biāo)串(subject string)內(nèi)搜索匹配指定的模式的串。函數(shù)如果找到匹配的串返回他的位置,否則返回nil.最簡單的模式就是一個單詞,僅僅匹配單詞本身。比如,模式'hello'僅僅匹配目標(biāo)串中的"hello"。當(dāng)查找到模式的時候,函數(shù)返回兩個值:匹配串開始索引和結(jié)束索引。
local s = "hello world"
i,j = string.find(s,"hello")
print(i," ",j) -->1 5
print(string.find(s, "kity")) -->nil
string.find函數(shù)第三個參數(shù)是可選的:標(biāo)示目標(biāo)串中搜索的起始位置。當(dāng)我們想查找目標(biāo)串中所有匹配的子串的時候,這個選項非常有用。
local s = "\nare you ok!\n OK\n"
local t = {}
local i = 0
while true do
i = string.find(s,"\n",i+1)
if i == nil then break end
table.insert(t,i)
end
for k,v in pairs(t) do
print(k,"->",v)
end
更多建議: