佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > Lua字符串庫(kù)中的幾個(gè)重點(diǎn)函數(shù)介紹

Lua字符串庫(kù)中的幾個(gè)重點(diǎn)函數(shù)介紹

熱門標(biāo)簽:服務(wù)外包 鐵路電話系統(tǒng) 網(wǎng)站排名優(yōu)化 地方門戶網(wǎng)站 AI電銷 百度競(jìng)價(jià)排名 呼叫中心市場(chǎng)需求 Linux服務(wù)器

在《Lua中的一些庫(kù)》中也說到了,要對(duì)string庫(kù)的模式匹配進(jìn)行單獨(dú)的講解。對(duì)于字符串的處理,對(duì)于任何語(yǔ)言的學(xué)習(xí)來說,都是一個(gè)難點(diǎn),而且也是一個(gè)必會(huì)的知識(shí)點(diǎn)。給你一個(gè)字符串,讓你按照某種需求進(jìn)行處理,你不會(huì),那是多么尷尬的一件事情。所以,看完《Lua中的一些庫(kù)》和這篇文章之后,我爭(zhēng)取做到讓你在處理字符串時(shí),不再感到捉襟見肘,不再尷尬。

說到Lua中的模式匹配,基本上就是圍繞著以下幾個(gè)函數(shù)展開的:

1.find;
2.match;
3.gsub;
4.gmatch。

我的總結(jié)也就是圍繞著上面的四個(gè)函數(shù)展開的。請(qǐng)容我慢慢道來。

簡(jiǎn)單實(shí)用的find

string.find()函數(shù)用于在一個(gè)給定的目標(biāo)字符串中搜索一個(gè)模式。最簡(jiǎn)單的模式就是一個(gè)單詞,它只會(huì)匹配與自己完全相同的拷貝。當(dāng)find找到一個(gè)模式后,它會(huì)返回兩個(gè)值:匹配到的起始索引和結(jié)尾索引;如果沒有找到任何匹配,它就返回nil。示例代碼:

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

local str = "Hello World"
local i, j = string.find(str, "Hello") -- 返回Hello在str中的起始位置和終止位置
print(i, j)

string.find函數(shù)還具有一個(gè)可選的第三個(gè)參數(shù),它是一個(gè)索引,告訴函數(shù)應(yīng)該從目標(biāo)字符串的哪個(gè)位置開始搜索。當(dāng)我們處理一個(gè)字符串中與給定模式相匹配的所以內(nèi)容時(shí),這個(gè)設(shè)置是非常有用的。我們可以循環(huán)的進(jìn)行查找操作。當(dāng)然了,這里只是說了最普通,也是最簡(jiǎn)單的一種方式,對(duì)于第二個(gè)參數(shù),我們完全可以傳遞一個(gè)正則表達(dá)式,也就是一個(gè)pattern,進(jìn)行正則匹配。示例代碼:

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

local str = "Hello12345World"
local i, j = string.find(str, "%d+")
print(i, j) -- 6   10

find的兄弟match

函數(shù)string.match與string.find非常相似,它也是用于在一個(gè)字符串中搜索一種模式。區(qū)別在于,string.match返回的是目標(biāo)字符串中與模式相匹配的那部分子串,并不是該模式所在的位置。示例代碼:

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

local str = "Hello12345World"
local subStr = string.match(str, "%d+")
print(subStr)
 
local i, j =string.find(str, "%d+")
subStr =string.sub(str, i, j)
print(subStr)
 
-- 是不是可以認(rèn)為match等于find + sub呢?

match和find是如此的相近,因此,在實(shí)際開發(fā)中,按照實(shí)際的需要,決定采用哪個(gè)。

替換利器gsub

string.gsub有3個(gè)參數(shù):目標(biāo)字符串、模式和替換字符串。它的基本用法是將目標(biāo)字符串中所有出現(xiàn)模式的地方替換為目標(biāo)字符串。來看一段簡(jiǎn)短的代碼,就什么都明白了。

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

local str = "Hello World"
local strResult = string.gsub(str, "Hello", "Jelly")
print(strResult) -- Jelly World

另外gsub還有可選的第四個(gè)參數(shù),可以限制替換的次數(shù)。示例代碼如下:

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

local str = "Hello World"
 
-- 這里不限制替換次數(shù)
local strResult, cnt = string.gsub(str, "l", "o")
print(strResult) -- Heooo Worod
print(cnt) -- 實(shí)際替換的次數(shù)
 
-- 開始限制替換次數(shù)
strResult, cnt = string.gsub(str, "l", "o", 1)
print(strResult) -- Heolo World
print(cnt) -- 就替換了一次

這里還有重點(diǎn)需要介紹,也就是gsub的強(qiáng)大之處。先看一段代碼,然后再做介紹。
復(fù)制代碼 代碼如下:

local replaceTb = {hello = "Jelly", world = "Think"}
 
local str = "hello world"
 
-- 注意,第3個(gè)參數(shù)是一個(gè)table
local strResult = string.gsub(str, "hello", replaceTb)
print(strResult) -- Jelly world
 
strResult = string.gsub(strResult, "world", replaceTb)
print(strResult) -- Jelly Think
 
strResult = string.gsub(strResult, "hello", replaceTb)
print(strResult) -- Jelly Think

可以看到,gsub的第三個(gè)參數(shù)是一個(gè)table,也就是說,當(dāng)gsub的第三個(gè)參數(shù)是一個(gè)table時(shí),如果在查找的字符串中有與第二個(gè)參數(shù)相匹配的內(nèi)容,就會(huì)將該內(nèi)容作為key,在table中查找該key對(duì)應(yīng)的value;如果該table中沒有這個(gè)key,則不進(jìn)行替換;上面的代碼就是表明這個(gè)意思。接下來再來看一段比較神奇的代碼:
復(fù)制代碼 代碼如下:

local replaceFunc = function (str)
    return str .. "JellyThink"
end
local str = "hello world"
-- 注意,第3個(gè)參數(shù)是一個(gè)table
local strResult = string.gsub(str, "hello", replaceFunc)
print(strResult) -- helloJellyThink world

沒有看錯(cuò),gsub的第三個(gè)參數(shù)還可以是一個(gè)函數(shù),該函數(shù)的參數(shù)是被匹配的字符串,該函數(shù)的返回值將會(huì)作為目標(biāo)字符串去進(jìn)行替換匹配的內(nèi)容。

沒法形容的gmatch

我也不知道要怎么形容gmatch,gmatch會(huì)返回一個(gè)迭代器函數(shù),你可以使用這個(gè)迭代器函數(shù)去迭代匹配的所有內(nèi)容??聪铝写a:

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

local str = "Hello World"
local iteratorFunc = string.gmatch(str, "%a+") -- %a+表示匹配所有單詞
 
for i in iteratorFunc do
    print(i)
end

如果你對(duì)迭代器還不熟悉的話,可以看這里。我現(xiàn)在就使用find來實(shí)現(xiàn)一個(gè)我們自己的gmatch,功能和gmatch是差不多的。代碼如下:

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

local str = "Hello World"
 
-- 使用find來實(shí)現(xiàn)一個(gè)自己的gmatch
local myGmatch = function (s, pattern)
  local resultTb = {} -- 相當(dāng)于迭代器中的恒定狀態(tài)
  local index = 0 -- 相當(dāng)于迭代器中的控制變量
 
  local i, j = string.find(s, pattern)
  while i do
    resultTb[#resultTb + 1] = string.sub(s, i, j)
    i, j = string.find(s, pattern, j + 1)
  end
 
  return function () -- 返回一個(gè)迭代器函數(shù)
    index = index + 1
    return resultTb[index]
  end
end
 
for i in myGmatch(str, "%a+") do
  print(i)
end

總結(jié)

這里就總結(jié)到這里了,這篇文章很詳細(xì)的幾個(gè)字符串庫(kù)中我認(rèn)為比較重要的函數(shù)。我想我已經(jīng)總結(jié)的很詳細(xì)了,寫了那么多的示例代碼,應(yīng)該還好理解。就這樣了。希望對(duì)大家有用。最后,我希望大家也和我一起分享,分享你的學(xué)習(xí)心得,分享你的IT人生,期待。。。

您可能感興趣的文章:
  • Lua中的string庫(kù)(字符串函數(shù)庫(kù))總結(jié)
  • Lua中的函數(shù)(function)、可變參數(shù)、局部函數(shù)、尾遞歸優(yōu)化等實(shí)例講解
  • Lua中的一些常用函數(shù)庫(kù)實(shí)例講解
  • Lua中的模塊與module函數(shù)詳解
  • Lua中的函數(shù)知識(shí)總結(jié)
  • Lua的table庫(kù)函數(shù)insert、remove、concat、sort詳細(xì)介紹
  • Lua中的常用函數(shù)庫(kù)匯總
  • Lua中的面向?qū)ο缶幊淘斀?/li>
  • Lua面向?qū)ο笾惡屠^承
  • Lua面向?qū)ο笾嘀乩^承、私密性詳解
  • Lua面向?qū)ο缶幊虒W(xué)習(xí)筆記
  • Lua中函數(shù)與面向?qū)ο缶幊痰幕A(chǔ)知識(shí)整理

標(biāo)簽:黃山 湘潭 銅川 衡水 崇左 仙桃 蘭州 湖南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Lua字符串庫(kù)中的幾個(gè)重點(diǎn)函數(shù)介紹》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    全州县| 莱芜市| 鄂托克前旗| 弥勒县| 通渭县| 堆龙德庆县| 阿荣旗| 包头市| 曲沃县| 靖宇县| SHOW| 达日县| 祁连县| 宜州市| 定远县| 平遥县| 六枝特区| 东阳市| 长乐市| 大方县| 怀安县| 子洲县| 肇州县| 乃东县| 永清县| 东丰县| 阳信县| 那曲县| 顺义区| 大同市| 阜新市| 龙井市| 江西省| 宝丰县| 金寨县| 望奎县| 华池县| 三明市| 巴青县| 莱西市| SHOW|