国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 開(kāi)發(fā) > 綜合 > 正文

Lua字符串庫(kù)(string庫(kù))學(xué)習(xí)筆記

2024-07-21 23:04:20
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

Lua 最強(qiáng)大的特性之一就是它的字符串處理能力,它支持字符格式化輸出,具有可擴(kuò)展的模式匹配查找功能,以及一些實(shí)用的字符操作,例如查詢、截取、替換和刪除等字符串操作,這些字符串操作函數(shù)都封裝在一個(gè)名為 string 的模塊里。

Lua 里的字符索引是從 1 開(kāi)始,索引值也可以是負(fù)數(shù),這種情況將被解釋成向后索引,從字符串末尾開(kāi)始算起。

下面是 Lua 5.2 提供的字符串操作函數(shù):

byte

函數(shù) string.byte 把字符串里的第 i 個(gè)字符轉(zhuǎn)為 ASCII 編碼,默認(rèn)是輸出第一個(gè)字符的編碼(只有一個(gè)參數(shù)的話),用法:

 

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

string.byte (s [, i [, j]])

 

例子:

 

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

print(string.byte("abc")) //echo:97

 

print(string.byte("abc", 2))//echo:98

 

char

函數(shù) string.char 是把一個(gè) ASCII 編碼轉(zhuǎn)換為對(duì)應(yīng)的字符,用法:

 

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

string.char (asc1, ...)

 

例子:

 

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

print(string.char(97)) //echo a

 

print(string.char(99, 100, 101)) //echo cde

 

dump

函數(shù) string.dump 返回一個(gè)函數(shù)二進(jìn)制形式的字符串,用法:

 

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

string.dump (function)

 

參數(shù) function 是一個(gè) Lua 函數(shù):

 

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

function test()
    print("just a test")
end
print(string.dump(test))

 

函數(shù) string.dump 實(shí)現(xiàn)了函數(shù)的序列化,函數(shù)可以很輕松的傳遞,并在其他作用域調(diào)用。函數(shù) string.dump 出來(lái)的二進(jìn)制字符串,可以用 load 函數(shù)反序列回來(lái)直接調(diào)用。

 

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

function test()
    print("just a test")
end
local sd = string.dump(test)
print(sd)
local ls = load(sd)
print(ls)
ls()

 

find

函數(shù) string.find 查找字符串 s 里第一個(gè)符合查找字符 pattern 的位置,用法:

 

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

string.find (s, pattern [, init [, plain]])

 

如果找到了目標(biāo)字符 pattern,則返回它的開(kāi)始和結(jié)束位置:

 

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

start, end = string.find("just a test", "st")
print(start, end)

 

如果沒(méi)有找到,則返回 nil:

 

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

print(string.find("just a test", "dhq.me"))

 

format

函數(shù) string.format 用于把字符串格式化輸出,用法:

 

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

string.format (formatstring, ···)

string.format 函數(shù)的第一個(gè)參數(shù)是用來(lái)指定字符串的格式,例如:

 

 

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

print(string.format("%s is %d", "ten", 10))

 

上面例子里的 %s 表示字符串,%d 表示數(shù)字,它們是 Lua 的格式化輸出符號(hào)。

string.format 函數(shù)的用法跟 C 語(yǔ)言里的 printf 函數(shù)類似,例如它可以像 printf 那樣輸出指定位數(shù)的數(shù)字:

 

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

Pi = 3.1415926
print(string.format("Pi is %.2f", Pi))

 

Lua 的字符格式化輸出符號(hào)列表:

 

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

.           所有字符
%a          字母
%c          控制符
%d          數(shù)字
%D          非數(shù)字
%l          小寫(xiě)字母
%p          標(biāo)點(diǎn)符號(hào)
%s          字符串
%u          大寫(xiě)字母
%w          字母數(shù)字
%x          十六進(jìn)制數(shù)
%z          用 0 表示的字符

 

gmatch

函數(shù) string.gmatch 會(huì)返回一個(gè)迭代函數(shù),尅通過(guò)該函數(shù)遍歷到一個(gè)字符串 s 中所有出現(xiàn)指定匹配模式 pattern 的地方,用法:

 

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

string.gmatch (s, pattern)

 

例如下面是找出字符串 s 里的所有單詞:

 

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

s = "just a test"
for w in string.gmatch(s, "%a+") do
    print(w)
end

 

gsub

函數(shù) string.gsub 用于全局字符串替換,字符串 s 里滿足匹配模式 pattern 格式的字符都會(huì)被替換成 repl 參數(shù)的值,用法:

 

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

string.gsub (s, pattern, repl [, n])

 

例如:

 

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

print(string.gsub("just a test", "st", "*"))

 

匹配模式 pattern 可以是一個(gè)正則:

 

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

s = "num is 1234567890"
print(string.gsub(s, "%d", "*"))

 

可在函數(shù)的最后加上一個(gè)可選參數(shù) n,表示指定要替換的次數(shù):

 

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

s = "sethook, setlocal, setmetatable, setupvalue, setuservalue"
print(string.gsub(s, "s%a+", "S", 2))

 

len

函數(shù) string.len 用于返回字符串 s 的長(zhǎng)度,用法:

 

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

string.len (s)

 

例子:

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

print(string.len("abcdefg"))

 

lower

函數(shù) string.lower 用于把字符串 s 里的字母轉(zhuǎn)為小寫(xiě),用法:

 

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

string.lower (s)

 

例如:

 

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

print(string.lower("AbCdEfG"))

 

match

函數(shù) string.match 用于查找字符串 s 里第一個(gè)匹配對(duì)模式 pattern 的值,并返回匹配值,用法:

 

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

string.match (s, pattern [, init])

 

上面參數(shù) init 是可選, 表示查找過(guò)程的起點(diǎn), 默認(rèn)從 1 開(kāi)始:

 

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

print(string.match("just a test", "test"))

 

參數(shù) patter 可以是一個(gè)正則模式:

 

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

t = "today is 2003-5-31"
print(string.match(t, "%d+-%d+-%d+"))

 

如果 pattern 為空,則返回整個(gè)字符串;如果沒(méi)匹配成功,則返回 nil。

 

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

print(string.match("abcdabcd", "a"))

 

rep

函數(shù) string.rep 返回一個(gè)由分隔符 sep 隔開(kāi)的重復(fù)(repeat)n 次字符 s 的字符串,用法:

 

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

string.rep (s, n [, sep])

默認(rèn)的分隔符 sep 是空字符。

 

 

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

print(string.rep("repeat", 3))

 

reverse

函數(shù) string.reverse 用于倒轉(zhuǎn)一個(gè)字符串 s 的排序,用法:

 

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

string.reverse (s)

 

例如:

 

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

print(string.reverse("reverse"))

 

sub

函數(shù) string.sub 用于從字符串 s 里截取一個(gè)從第 i 個(gè)字符到第 j 個(gè)字符間的子字符串,用法:

 

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

string.sub (s, i [, j])

例如:

 

 

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

print(string.sub("abcdefg", 2, 5))

參數(shù) i 可以是負(fù)數(shù),這種情況下,子串的位置從字符串 s 的最后開(kāi)始算起:

 

 

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

print(string.sub("abcdefg", -4, -2))

參數(shù) end 省略的話,則會(huì)返回從 i 到字符串末尾的子字符串:

 

 

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

print(string.sub("abcdefg", 3))

 

upper

函數(shù) string.upper 用于把字符串 s 里的字母轉(zhuǎn)為大寫(xiě),用法:

 

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

string.upper (s)

 

例如:

 

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

print(string.upper("AbCdEfG"))
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 庆阳市| 兴化市| 左权县| 宁武县| 桦南县| 竹山县| 平度市| 东乡县| 嘉善县| 炎陵县| 施甸县| 溧阳市| 长垣县| 秦皇岛市| 长治市| 张家口市| 开化县| 平邑县| 鄂尔多斯市| 穆棱市| 黄陵县| 易门县| 余庆县| 凌源市| 无极县| 蚌埠市| 米林县| 北流市| 南皮县| 凤庆县| 凉山| 敦煌市| 五大连池市| 安远县| 卫辉市| 达孜县| 凉山| 连云港市| 中江县| 宁城县| 东安县|