婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Lua字符串庫(string庫)學習筆記

Lua字符串庫(string庫)學習筆記

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

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

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

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

byte

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

復制代碼 代碼如下:

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

例子:

復制代碼 代碼如下:

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

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

char

函數 string.char 是把一個 ASCII 編碼轉換為對應的字符,用法:

復制代碼 代碼如下:

string.char (asc1, ...)

例子:

復制代碼 代碼如下:

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

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

dump

函數 string.dump 返回一個函數二進制形式的字符串,用法:

復制代碼 代碼如下:

string.dump (function)

參數 function 是一個 Lua 函數:

復制代碼 代碼如下:

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

函數 string.dump 實現了函數的序列化,函數可以很輕松的傳遞,并在其他作用域調用。函數 string.dump 出來的二進制字符串,可以用 load 函數反序列回來直接調用。

復制代碼 代碼如下:

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

find

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

復制代碼 代碼如下:

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

如果找到了目標字符 pattern,則返回它的開始和結束位置:

復制代碼 代碼如下:

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

如果沒有找到,則返回 nil:

復制代碼 代碼如下:

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

format

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

復制代碼 代碼如下:

string.format (formatstring, ···)

string.format 函數的第一個參數是用來指定字符串的格式,例如:

復制代碼 代碼如下:

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

上面例子里的 %s 表示字符串,%d 表示數字,它們是 Lua 的格式化輸出符號。

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

復制代碼 代碼如下:

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

Lua 的字符格式化輸出符號列表:

復制代碼 代碼如下:

.           所有字符
%a          字母
%c          控制符
%d          數字
%D          非數字
%l          小寫字母
%p          標點符號
%s          字符串
%u          大寫字母
%w          字母數字
%x          十六進制數
%z          用 0 表示的字符

gmatch

函數 string.gmatch 會返回一個迭代函數,尅通過該函數遍歷到一個字符串 s 中所有出現指定匹配模式 pattern 的地方,用法:

復制代碼 代碼如下:

string.gmatch (s, pattern)

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

復制代碼 代碼如下:

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

gsub

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

復制代碼 代碼如下:

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

例如:

復制代碼 代碼如下:

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

匹配模式 pattern 可以是一個正則:

復制代碼 代碼如下:

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

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

復制代碼 代碼如下:

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

len

函數 string.len 用于返回字符串 s 的長度,用法:

復制代碼 代碼如下:

string.len (s)

例子:

復制代碼 代碼如下:

print(string.len("abcdefg"))

lower

函數 string.lower 用于把字符串 s 里的字母轉為小寫,用法:

復制代碼 代碼如下:

string.lower (s)

例如:

復制代碼 代碼如下:

print(string.lower("AbCdEfG"))

match

函數 string.match 用于查找字符串 s 里第一個匹配對模式 pattern 的值,并返回匹配值,用法:

復制代碼 代碼如下:

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

上面參數 init 是可選, 表示查找過程的起點, 默認從 1 開始:

復制代碼 代碼如下:

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

參數 patter 可以是一個正則模式:

復制代碼 代碼如下:

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

如果 pattern 為空,則返回整個字符串;如果沒匹配成功,則返回 nil。

復制代碼 代碼如下:

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

rep

函數 string.rep 返回一個由分隔符 sep 隔開的重復(repeat)n 次字符 s 的字符串,用法:

復制代碼 代碼如下:

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

默認的分隔符 sep 是空字符。

復制代碼 代碼如下:

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

reverse

函數 string.reverse 用于倒轉一個字符串 s 的排序,用法:

復制代碼 代碼如下:

string.reverse (s)

例如:

復制代碼 代碼如下:

print(string.reverse("reverse"))

sub

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

復制代碼 代碼如下:

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

例如:

復制代碼 代碼如下:

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

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

復制代碼 代碼如下:

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

參數 end 省略的話,則會返回從 i 到字符串末尾的子字符串:

復制代碼 代碼如下:

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

upper

函數 string.upper 用于把字符串 s 里的字母轉為大寫,用法:

復制代碼 代碼如下:

string.upper (s)

例如:

復制代碼 代碼如下:

print(string.upper("AbCdEfG"))

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

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

巨人網絡通訊聲明:本文標題《Lua字符串庫(string庫)學習筆記》,本文關鍵詞  Lua,字符串,庫,string,學習,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Lua字符串庫(string庫)學習筆記》相關的同類信息!
  • 本頁收集關于Lua字符串庫(string庫)學習筆記的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 盐亭县| 崇左市| 天镇县| 志丹县| 连城县| 肇源县| 荆州市| 图木舒克市| 台北市| 城口县| 祁连县| 江西省| 金山区| 从江县| 甘泉县| 平远县| 永吉县| 宽甸| 无锡市| 泾源县| 武安市| 马公市| 五峰| 鄂伦春自治旗| 华坪县| 勃利县| 夏津县| 罗城| 鹤山市| 张家界市| 息烽县| 义马市| 高碑店市| 白城市| 四平市| 娄底市| 格尔木市| 宜阳县| 定襄县| 霞浦县| 彰武县|