校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > Lua中的string庫(字符串函數(shù)庫)總結(jié)

Lua中的string庫(字符串函數(shù)庫)總結(jié)

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

Lua解釋器對字符串的支持很有限。一個程序可以創(chuàng)建字符串并連接字符串,但不能截取子串,檢查字符串的大小,檢測字符串的內(nèi)容。在Lua中操縱字符串的功能基本來自于string庫。

字符串庫中的一些函數(shù)是非常簡單的:

string.len(s)          返回字符串s的長度;
string.rep(s, n)      返回重復n次字符串s的串;你使用string.rep("a", 2^20)可以創(chuàng)建一個1M bytes的字符串(比如,為了測試需要);
string.lower(s)       將s中的大寫字母轉(zhuǎn)換成小寫(string.upper將小寫轉(zhuǎn)換成大寫)。如果你想不關心大小寫對一個數(shù)組進行排序的話,你可以這樣:

復制代碼 代碼如下:

table.sort(a, function (a, b) return string.lower(a) string.lower(b) end)

string.upper(s)       將s中的小寫字母轉(zhuǎn)換成大寫
                            string.upper和string.lower都依賴于本地環(huán)境變量。所以,如果你在 European Latin-1環(huán)境下,表達式:
 
復制代碼 代碼如下:

string.upper("a??o")    --> "A??O"

string.sub(s,i,j)      函數(shù)截取字符串s的從第i個字符到第j個字符之間的串。Lua中,字符串的第一個字符索引從1開始。你也可以使用負索引,負索引從字符串的結(jié)尾向前計數(shù):-1指向最后一個字符,-2指向倒數(shù)第二個,以此類推。所以, string.sub(s, 1, j)返回字符串s的長度為j的前綴;string.sub(s, j, -1)返回從第j個字符開始的后綴。如果不提供第3個參數(shù),默認為-1,因此我們將最后一個調(diào)用寫為string.sub(s, j);string.sub(s, 2, -2)返回去除第一個和最后一個字符后的子串。

復制代碼 代碼如下:

s = "[in brackets]"
print(string.sub(s, 2, -2)) --> in brackets

記住:Lua中的字符串是恒定不變的。string.sub函數(shù)以及Lua中其他的字符串操作函數(shù)都不會改變字符串的值,而是返回一個新的字符串。一個常見的錯誤是:

復制代碼 代碼如下:

string.sub(s, 2, -2)

認為上面的這個函數(shù)會改變字符串s的值。如果你想修改一個字符串變量的值,你必須將變量賦給一個新的字符串:

復制代碼 代碼如下:

s = string.sub(s, 2, -2)

string.char函數(shù)和string.byte函數(shù)用來將字符在字符和數(shù)字之間轉(zhuǎn)換。string.char獲取0個或多個整數(shù),將每一個數(shù)字轉(zhuǎn)換成字符,然后返回一個所有這些字符連接起來的字符串。string.byte(s, i)將字符串s的第i個字符的轉(zhuǎn)換成整數(shù);第二個參數(shù)是可選的,缺省情況下i=1。下面的例子中,我們假定字符用ASCII表示:

復制代碼 代碼如下:

print(string.char(97)) --> a
i = 99; print(string.char(i, i+1, i+2)) --> cde
print(string.byte("abc")) --> 97
print(string.byte("abc", 2)) --> 98
print(string.byte("abc", -1)) --> 99

上面最后一行,我們使用負數(shù)索引訪問字符串的最后一個字符。

Lua提供了string.format()函數(shù)來生成具有特定格式的字符串, 函數(shù)的第一個參數(shù)是格式(formatstring), 之后是對應格式中每個代號的各種數(shù)據(jù). 由于格式字符串的存在, 使得產(chǎn)生的長字符串可讀性大大提高了. 這個函數(shù)的格式很像C語言中的printf().函數(shù)string.format在用來對字符串進行格式化的時候,特別是字符串輸出,是功能強大的工具。這個函數(shù)有兩個參數(shù),你完全可以照C語言的printf來使用這個函數(shù)。第一個參數(shù)為格式化串:由指示符和控制格式的字符組成。指示符后的控制格式的字符可以為:十進制'd';十六進制'x';八進制'o';浮點數(shù)'f';字符串's'。在指示符'%'和控制格式字符之間還可以有其他的選項:用來控制更詳細的格式,比如一個浮點數(shù)的小數(shù)的位數(shù):

格式字符串可能包含以下的轉(zhuǎn)義碼:

復制代碼 代碼如下:

%c - 接受一個數(shù)字, 并將其轉(zhuǎn)化為ASCII碼表中對應的字符
%d, %i - 接受一個數(shù)字并將其轉(zhuǎn)化為有符號的整數(shù)格式
%o - 接受一個數(shù)字并將其轉(zhuǎn)化為八進制數(shù)格式
%u - 接受一個數(shù)字并將其轉(zhuǎn)化為無符號整數(shù)格式
%x - 接受一個數(shù)字并將其轉(zhuǎn)化為十六進制數(shù)格式, 使用小寫字母
%X - 接受一個數(shù)字并將其轉(zhuǎn)化為十六進制數(shù)格式, 使用大寫字母
%e - 接受一個數(shù)字并將其轉(zhuǎn)化為科學記數(shù)法格式, 使用小寫字母e
%E - 接受一個數(shù)字并將其轉(zhuǎn)化為科學記數(shù)法格式, 使用大寫字母E
%f - 接受一個數(shù)字并將其轉(zhuǎn)化為浮點數(shù)格式
%g(%G) - 接受一個數(shù)字并將其轉(zhuǎn)化為%e(%E, 對應%G)及%f中較短的一種格式
%q - 接受一個字符串并將其轉(zhuǎn)化為可安全被Lua編譯器讀入的格式
%s - 接受一個字符串并按照給定的參數(shù)格式化該字符串

為進一步細化格式, 可以在%號后添加參數(shù). 參數(shù)將以如下的順序讀入:

(1) 符號: 一個+號表示其后的數(shù)字轉(zhuǎn)義符將讓正數(shù)顯示正號. 默認情況下只有負數(shù)顯示符號.
(2) 占位符: 一個0, 在后面指定了字串寬度時占位用. 不填時的默認占位符是空格.
(3) 對齊標識: 在指定了字串寬度時, 默認為右對齊, 增加-號可以改為左對齊.
(4) 寬度數(shù)值
(5) 小數(shù)位數(shù)/字串裁切: 在寬度數(shù)值后增加的小數(shù)部分n, 若后接f(浮點數(shù)轉(zhuǎn)義符, 如%6.3f)則設定該浮點數(shù)的小數(shù)只保留n位, 若后接s(字符串轉(zhuǎn)義符, 如%5.3s)則設定該字符串只顯示前n位.

在這些參數(shù)的后面則是上述所列的轉(zhuǎn)義碼類型(c, d, i, f, ...).

復制代碼 代碼如下:

print(string.format("pi = %.4f", PI))
      --> pi = 3.1416
d = 5; m = 11; y = 1990
print(string.format("%02d/%02d/%04d", d, m, y))
        --> 05/11/1990
tag, title = "h1", "a title"
print(string.format("%s>%s/%s>", tag, title, tag))
        --> h1>a title/h1>

第一個例子,%.4f代表小數(shù)點后面有4位小數(shù)的浮點數(shù)。第二個例子%02d代表以固定的兩位顯示十進制數(shù),不足的前面補0。而%2d前面沒有指定0,不足兩位時會以空白補足。對于格式串部分指示符得詳細描述清參考lua手冊,或者參考C手冊,因為Lua調(diào)用標準C的printf函數(shù)來實現(xiàn)最終的功能。

以下是一些例子:

復制代碼 代碼如下:

string.format("%%c: %c", 83)            輸出S
string.format("%+d", 17.0)              輸出+17
string.format("%05d", 17)               輸出00017
string.format("%o", 17)                 輸出21
string.format("%u", 3.14)               輸出3
string.format("%x", 13)                 輸出d
string.format("%X", 13)                 輸出D
string.format("%e", 1000)               輸出1.000000e+03
string.format("%E", 1000)               輸出1.000000E+03
string.format("%6.3f", 13)              輸出13.000
string.format("%q", "One\nTwo")         輸出"One\
                                          Two"
string.format("%s", "monkey")           輸出monkey
string.format("%10s", "monkey")         輸出    monkey
string.format("%5.3s", "monkey")        輸出  mon

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

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

巨人網(wǎng)絡通訊聲明:本文標題《Lua中的string庫(字符串函數(shù)庫)總結(jié)》,本文關鍵詞  Lua,中的,string,庫,字符串,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Lua中的string庫(字符串函數(shù)庫)總結(jié)》相關的同類信息!
  • 本頁收集關于Lua中的string庫(字符串函數(shù)庫)總結(jié)的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 深泽县| 谢通门县| 丹江口市| 灵台县| 建湖县| 曲阜市| 屏东市| 芜湖县| 姜堰市| 察雅县| 临清市| 南溪县| 商南县| 遂溪县| 杭州市| 兴城市| 赤水市| 大兴区| 思茅市| 海晏县| 松溪县| 陆河县| 环江| 和龙市| 红安县| 吴川市| 九龙县| 简阳市| 观塘区| 清苑县| 宁晋县| 彭山县| 沙洋县| 莱芜市| 辽中县| 隆子县| 太原市| 桑植县| 金阳县| 阳高县| 浑源县|