㈠ lua腳本怎麼取出自己想要的的部分字元
你好,以前沒接觸過lua,剛自己試了一下,就按照你問題中的"23^Hello^你好^2000^world.txt"這個字元串為例,以^為分隔符來說吧:
---------------start---------------
str = "23^Hello^你好^2000^world.txt"
list = table.pack()
for w in string.gmatch(str, "[^^]+") do
print(w)
table.insert(list, w)
end
---------------start---------------
解釋:代碼共6行,
第1行:定義一個變數str,內容為"23^Hello^你好^2000^world.txt",這也是我們要處理的字元串.
第二行: 定義一個空列表,它是用在下面的for循環中,存放以"^"作為分隔符的每一部分
第三行:簡單來看是個for循環,深入一點來看,也就是string.gmatch(str,"[^^]+")這部分需要解釋一下,它表示調用的是string庫的gmatch()函數,這個函數有兩個參數,第1個參數為要處理的字元串,咱們這里就是上面定義的str,第二個參數就是我們要在這個字元串中匹配什麼樣的內容,這里的匹配內容寫的是"[^^]+",學過正則的很好理解,單純的[abc]表示匹配任意單個字元a或b或c,有一點特殊的是一旦[]中的字元是以^打頭的,則表示匹配任意非[]中列出的字元,如[^abc]表示匹配任意除abc外的其它任一字元,所以[^^]解釋為匹配除^外的任一字元,舉例來說,如果我們有字元串"23^Hello",如果用[^^]匹配的話,最終得到的是7個單個字元,即"2","3","H","e","l","l","o",顯示這不符合我們的題意,所以在這基礎上改進了一下,即在其後又加了個+號,[^^]+,這里的+號表示盡可能多地匹配它前面內容,這里也就是盡可能多地匹配[^^],所以[^^]+在處理"23^Hello"的時候,結果得到的就是"23","Hello".這里關於用到的這個正則說的不是太清楚,多練練就明白了。最後,第3行把函數部分給替換掉後,可以理解為:for w in [23,Hello,你好,2000,world.txt],每次從[]中取一個值賦給w,然後執行for下面的語句,接著往下看
第4行,接第3行尾,就是把每次賦給w的值都列印出來
第5行,將每次賦給w的值都追加到列表list中
第6行,for循環語法上的閉合關鍵字,這個沒啥說的
到此,我們得到了一個列表值為[23,Hello,你好,2000,world.txt]的list,此時我們就可以使用list[n]來取我們想要的值了 。
*.如果你要問上面最3條最後不都有[23,Hello,你好,2000,world.txt]了嘛,為啥還要那麼麻煩,直接使用string.gmatch()函數不就行了嘛,其實第3條結尾我那麼寫只是為了讓你好理解,實際上gmatch()函數的返回值並不是列表,而是一個可迭代的函數,而for循環的作用就是把gmatch()函數返回的這個可迭代的函數中的每個元素都取出來並賦給列表list
*.說的有點啰嗦了,希望對你有幫助吧,另外,我從沒用過lua,也是剛查了查,自己實踐了一下,希望不會形成誤導
㈡ lua中怎麼替換掉字元串中的$字元
a = "我們$a";
b = string.gsub(a, "\\$", "*");
print(b);
說明:
"\\$"
因為$是模式匹配的特殊字元, 所以需要在前面加 \
在字元串里, \ 是特殊字元, 所以是 \\
最後就是 "\\$"
㈢ lua中怎麼從字元串里截取指定字元間的字元 如 a="agig12iigvt" 我要截取gig和
方法一:
a="agig12iigvt"
i, j = a:find("gig.-gvt") --定位
print(a:sub(i+3, j-3)) --去除頭尾特徵
方法二:
b = a:match("gig.-gvt") --提取包含頭尾的字元串
print(b:sub(4, string.len(b)-3)) --去除頭尾
總的來說通過string.match或者string.sub來提取字元串,結合patterns(弱化版的正則表達式)進行通配;具體得視源字元串的數據特徵而定
㈣ lua如何從字元串提取某一個字元
lua里不像c一樣區分字元串和字元。
比如:
b = a:match("gig.-gvt") --提取包含頭尾的字元串
print(b:sub(4, string.len(b)-3)) --去除頭尾
總的來說通過string.match或者string.sub來提取字元串,結合patterns(弱化版的正則表達式)進行通配;具體得視源字元串的數據特徵而定。
function string.split(input, delimiter)
input = tostring(input)
delimiter = tostring(delimiter)
if (delimiter=='') then return false end
local pos,arr = 0, {}
-- for each divider found
for st,sp in function() return string.find(input, delimiter, pos, true) end do
table.insert(arr, string.sub(input, pos, st - 1))
pos = sp + 1
end
table.insert(arr, string.sub(input, pos))
return arr
end
(4)lua過濾特殊字元擴展閱讀:
Lua還具有其它一些特性:同時支持面向過程(procere-oriented)編程和函數式編程(functional programming);自動內存管理;只提供了一種通用類型的表(table),用它可以實現數組,哈希表,集合,對象;語言內置模式匹配;
閉包(closure);函數也可以看做一個值;提供多線程(協同進程,並非操作系統所支持的線程)支持;通過閉包和table可以很方便地支持面向對象編程所需要的一些關鍵機制,比如數據抽象,虛函數,繼承和重載等。
㈤ lua 登錄驗證 怎麼判斷字元串不含非法字元
把要判斷的字元或字元正則表達式(注意格式轉義)放到table中,用string.find一個個查找。
㈥ lua模式匹配中怎樣匹配中文標點符號,%p只能匹配英文標點,不能匹配出中文的(我試過了)
這個很簡單啊,你的字元串相匹配。您更換邏輯有點亂的關鍵。
[全字匹配]
通常你在編輯器中替換文本,替換所有匹配整個單詞] [區分大小寫的選項。
你的盾牌有一組詞明顯地分為兩大類,但沒有什麼區別。
盧阿我打招呼去方程的原話。例如,更換是不可能取代賓果走在去
主題打招呼等必須更換的是一個完整的單詞(因為匹配的符號一般是匹配一個空格)的一部分。
例如:將「主題」中的「主題」部分將「主題曲」取代
[解決方案]做第一個字包含了中國與當然的空間相匹配,一些錯誤仍需要解決的問題,如從比賽去掉了常見的中國符號,我會做一個簡單的演示。
過程的下一個標點符號自己。
㈦ lua 怎麼分割 字元串,然後進行比對過濾重復
string.match(a,".?(%d-).?")這個應該可以 a="111.222.333.444"
㈧ lua腳本語言中 怎麼過濾中文下的特殊字元
你的問題寫的有些不太清楚
如果你是要替換的話
s = "這是一句話"
s = string.gsub(s,"一句","*")
這樣就能把 一句 這2個字替換成星號了 你是這個意思么
㈨ lua中怎麼替換掉字元串中的$特殊字元
由於$是模式的特殊字元, 要使用普通的$字元, 則去掉它的特殊含義.
用 %$
㈩ lua中怎樣屏蔽掉一個字元串中的所有中文標點符號(%p只能實現過濾英文的標點符號)
string.gsub(s,'%,','')
半形的符號似乎也是特殊字元把 也加上轉義把
豆號問號什麼符號你就多加幾句把