日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

openresty开发系列18--lua的字符串string操作

發布時間:2025/3/20 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 openresty开发系列18--lua的字符串string操作 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

openresty開發系列18--lua的字符串string操作

string的相關操作

1)string.upper(s)
接收一個字符串 s,返回一個把所有小寫字母變成大寫字母的字符串。
print(string.upper("Hello Lua"))? -->output? HELLO LUA

2)string.lower(s)
接收一個字符串 s,返回一個把所有大寫字母變成小寫字母的字符串。
print(string.lower("Hello Lua"))? -->output?? hello lua

3)string.len(s)
接收一個字符串,返回它的長度
print(string.len("hello lua")) -->output? 9
使用此函數是不推薦的。推薦使用 # 運算符來獲取 Lua 字符串的長度。
print(#("hello lua")) -->output? 9
由于 Lua 字符串的長度是專門存放的,并不需要像 C 字符串那樣即時計算
因此獲取字符串長度的操作總是 O(1) 的時間復雜度。

4)string.find(s, p [, init [, plain]]) --查找子字符串

在 s 字符串中第一次匹配 p 字符串。若匹配成功,則返回 p 字符串中出現的開始位置和結束位置;
若匹配失敗,則返回 nil。

第三個參數 init 默認為 1,并且可以為負整數,
當 init 為負數時,表示從后往前數的字符個數;再從此索引處開始向后匹配字符串 p 。

第四個參數默認為 false,當其為 true 時,關閉模式匹配;只會把 p 看成一個字符串對待。

local find = string.find
print(find("abc cba", "ab"))
print(find("abc cba", "ab", 2))?? ?
print(find("abc cba", "ba", -1))?? ?
print(find("abc cba", "ba", -3))


-->output
1?? 2
nil
nil
6?? 7

模式匹配--lua正則表達式


local s = "am+df"
print(string.find(s, "m+", 1, false))??? -- 2??? 2、
其中字符 + 在 Lua 正則表達式中的意思是匹配在它之前的那個字符一次或者多次,
也就是說 m+ 在正則表達式里會去匹配 m, mm, mmm ……。


print(string.find(s, "m+", 1, true))??? -- 2??? 3
plain為true,關閉了模式匹配,p參數也就是"m+",當做了是個普通字符串,不進行模式匹配


5)string.format(formatstring, ...) --格式化輸出
按照格式化參數 formatstring,返回后面 ... 內容的格式化版本。
編寫格式化字符串的規則與標準 c 語言中 printf 函數的規則基本相同:
它由常規文本和指示組成,這些指示控制了每個參數應放到格式化結果的什么位置,及如何放入它們

一個指示由字符 % 加上一個字母組成,這些字母指定了如何格式化參數,
例如 d 用于十進制數、x 用于十六進制數、o 用于八進制數、f 用于浮點數、s 用于字符串等。
在字符 % 和字母之間可以再指定一些其他選項,用于控制格式的細節。

print(string.format("%.4f", 3.1415926))???? -- 保留4位小數
print(string.format("%d %x %o", 31, 31, 31))-- 十進制數31轉換成不同進制

d = 29; m = 7; y = 2015???????????????????? -- 一行包含幾個語句,用;分開
print(string.format("%s %02d/%02d/%d", "today is:", d, m, y))

-->output
3.1416
31 1f 37
today is: 29/07/2015


6)整型數字 與 字符互換
Lua 字符串總是由字節構成的。下標是從 1 開始的,這不同于像 C 和 Perl

string.byte(s [, i [, j ]])
返回字符 s[i]、s[i + 1]、s[i + 2]、······、s[j] 所對應的 ASCII 碼。
i 的默認值為 1,即第一個字節;j 的默認值為 i
print(string.byte("abc", 1, 3))
print(string.byte("abc", 3)) -- 缺少第三個參數,第三個參數默認與第二個相同,此時為 3
print(string.byte("abc"))??? -- 缺少第二個和第三個參數,此時這兩個參數都默認為 1

-->output
97? 98? 99
99
97
由于 string.byte 只返回整數,而并不像 string.sub 等函數那樣(嘗試)創建新的 Lua 字符串,
因此使用 string.byte 來進行字符串相關的掃描和分析是最為高效的,尤其是在被 LuaJIT 2 所 JIT 編譯之后。

string.char (...)
接收 0 個或更多的整數(整數范圍:0~255),返回這些整數所對應的 ASCII 碼字符組成的字符串。
當參數為空時,默認是一個 0。
print(string.char(96, 97, 98))
print(string.char())??????? -- 參數為空,默認是一個0,
??????????????????????????? -- 你可以用string.byte(string.char())測試一下
print(string.char(65, 66))

--> output
`ab

AB

如果你只是想對字符串中的單個字節進行檢查,使用 string.char 函數通常會更為高效。

7)string.match(s, p [, init])--匹配子字符串

在字符串 s 中匹配(模式)字符串 p,若匹配成功,則返回目標字符串中與模式匹配的子串;否則返回 nil。
第三個參數 init 默認為 1,并且可以為負整數,
當 init 為負數時,表示從后往前數的字符個數,在此索引處開始向后匹配字符串 p。

print(string.match("hello lua", "lua"))
print(string.match("lua lua", "lua", 2))? --匹配后面那個lua
print(string.match("lua lua", "hello"))
print(string.match("today is 27/7/2015", "%d+/%d+/%d+"))

-->output
lua
lua
nil
27/7/2015

string.match 目前并不能被 JIT 編譯,應 盡量 使用 ngx_lua 模塊提供的 ngx.re.match 等接口。

8)string.gmatch(s, p) --匹配多個字符串
返回一個迭代器函數,通過這個迭代器函數可以遍歷到在字符串 s 中出現模式串 p 的所有地方。
s = "hello world from Lua"
for w in string.gmatch(s, "%a+") do? --匹配最長連續且只含字母的字符串
??? print(w)
end

-->output
hello
world
from
Lua

t = {}
s = "from=world, to=Lua"
for k, v in string.gmatch(s, "(%a+)=(%a+)") do? --匹配兩個最長連續且只含字母的
??? t[k] = v??????????????????????????????????? --字符串,它們之間用等號連接
end
for k, v in pairs(t) do
print (k,v)
end

-->output
to????? Lua
from??? world

此函數目前并不能被 LuaJIT 所 JIT 編譯,而只能被解釋執行。應 盡量 使用 ngx_lua 模塊提供的 ngx.re.gmatch 等接口。

9)string.rep(s, n) --字符串拷貝
返回字符串 s 的 n 次拷貝。
print(string.rep("abc", 3)) --拷貝3次"abc"

-->output? abcabcabc

10)string.sub(s, i [, j]) --截取子字符串
返回字符串 s 中,索引 i 到索引 j 之間的子字符串。當 j 缺省時,默認為 -1,也就是字符串 s 的最后位置。
i 可以為負數。當索引 i 在字符串 s 的位置在索引 j 的后面時,將返回一個空字符串。
print(string.sub("Hello Lua", 4, 7))
print(string.sub("Hello Lua", 2))
print(string.sub("Hello Lua", 2, 1))??? --看到返回什么了嗎
print(string.sub("Hello Lua", -3, -1))

-->output
lo L
ello Lua

Lua


11)string.gsub(s, p, r [, n]) --替換子字符串
將目標字符串 s 中所有的子串 p 替換成字符串r??蛇x參數n,表示限制替換次數。
返回值有兩個,第一個是被替換后的字符串,第二個是替換了多少次。
print(string.gsub("Lua Lua Lua", "Lua", "hello"))
print(string.gsub("Lua Lua Lua", "Lua", "hello", 2)) --指明第四個參數

-->output
hello hello hello?? 3
hello hello Lua???? 2
此函數不能為 LuaJIT 所 JIT 編譯,而只能被解釋執行。一般我們推薦使用 ngx_lua 模塊提供的 ngx.re.gsub 函數。

12)string.reverse (s) --反轉
接收一個字符串 s,返回這個字符串的反轉。
print(string.reverse("Hello Lua"))? --> output: auL olleH

轉載于:https://www.cnblogs.com/reblue520/p/11433474.html

與50位技術專家面對面20年技術見證,附贈技術全景圖

總結

以上是生活随笔為你收集整理的openresty开发系列18--lua的字符串string操作的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。