1. string库中所有的字符索引从前往后是1,2,...;从后往前是-1,-2,...
2. string库中所有的function都不会直接操作字符串,而是返回一个结果
s = "[abc]"
string.len(s) <==返回5
string.rep("abc", 2) <==返回"abcabc"
string.lower("ABC") <==返回"abc"
string.upper("abc") <==返回"ABC"
string.sub(s, 2) <==返回"abc]"
string.sub(s, -2) <==返回"c]"
string.sub(s, 2, -2) <==返回"abc"
string.format(fmt, ...)返回一个类似printf的格式化字符串
string.find(s, pattern, pos)
第1个参数:源字符串
第2个参数:待搜索之模式串
第3个参数:A hint, 从pos位置开始搜索
找到匹配返回:匹配串开始和结束的位置,否则返回nil
简单的模式串
s = "hello world"
i, j = string.find(s, "hello")
print(i, j) --> 1 5
print(string.sub(s, i, j)) --> hello
print(string.find(s, "world")) --> 7 11
i, j = string.find(s, "l")
print(i, j) --> 3 3
print(string.find(s, "lll")) --> nil
格式化的模式串
s = "Deadline is 30/05/1999, firm"
date = "%d%d/%d%d/%d%d%d%d"
print(string.sub(s, string.find(s, date))) --> 30/05/1999
下面的表列出了Lua支持的所有字符类:
. 任意字符
%s 空白符
%p 标点字符
%c 控制字符
%d 数字
%x 十六进制数字
%z 代表0的字符
%a 字母
%l 小写字母
%u 大写字母
%w 字母和数字
上面字符类的大写形式表示小写所代表的集合的补集。例如,'%A'非字母的字符:
模式串中的特殊字符
( ) . % + - * ? [ ^ $
'%' 用作特殊字符的转义字符
'%.' 匹配点;
'%%' 匹配字符 '%'。
转义字符 '%'不仅可以用来转义特殊字符,还可以用于所有的非字母的字符。当对一个字符有疑问的时候,为安全起见请使用转义字符转义他。
用'[]'创建字符集
'[%w_]' 匹配字母数字和下划线
'[01]' 匹配二进制数字
'[%[%]]'匹配一对方括号
在'[]'中使用连字符'-'
'%d' 表示 '[0-9]';
'%x' 表示 '[0-9a-fA-F]'
'[0-7]' 表示 '[01234567]'
在'[]'开始处使用 '^' 表示其补集:
'[^0-7]' 匹配任何不是八进制数字的字符;
'[^\n]' 匹配任何非换行符户的字符。
'[^%s]' == '%S'
模式修饰符
+ 匹配前一字符1次或多次
* 匹配前一字符0次或多次;最长匹配
- 匹配前一字符0次或多次;最短匹配
? 匹配前一字符0次或1次
^ 匹配字符串开头
$ 匹配字符串结尾
捕获:用()将要捕获的部分包围起来
pair = "name = Anna"
firstidx, lastidx, key, value = string.find(pair, "(%a+)%s*=%s*(%a+)")
print(key, value) <== name Anna
拷贝捕获(%1-%9)
s = "abc \"it\'s a cat\""
_,_,_,q = string.find(s, "([\"'])(.-)%1"))
print(q) <== it's a cat 如果%d代表第几个捕获的拷贝。
string.gsub(s, pattern, reps)
第1个参数:源字符串
第2个参数:待替换之模式串
第3个参数:替换为reps
将s中所有符合pattern的字串替换为reps,返回结果串+匹配数
print(string.gsub("hello, world", "o", "a")) <== hella, warld 2
gsub也可以用拷贝捕获技巧
print(string.gsub("hello, world", "(o)", "%1-%1")) <== hello-o, wo-orld 2
print(string.gsub("hello Lua", "(.)(.)", "%2%1")) <== ehll ouLa 4
function trim (s) return (string.gsub(s, "^%s*(.-)%s*$", "%1")) end <== 注意匹配数用括号丢弃
string.gsub(s, pattern, func)
第3个参数:自定义函数,对找到的匹配操作,并传出替换值
s, n = string.gsub("hello world", "l+", function(s) return "xxx" end)
print(s, n) <== hexxxo worxxxd 2
string.gfind(s, pattern)
返回一个迭代器,迭代器每执行一次,返回下一个匹配串;
iter = string.gfind("a=b c=d", "[^%s+]=[^%s+]")
print(iter()) <== a=b
print(iter()) <== c=d
通常用于泛性for循环,下面的例子结果同上
for s in string.gfind("a=b c=d", "[^%s+]=[^%s+]") do
print(s)
end
2.Addon
--string.dump(function)。返回指定函数的二进制代码(函数必须是Lua函数,并且没有up value)
--[[Example:将一个函数转换成二进制码,输出;再换回来,输出;再执行。
function DumpTest()
print("string.dump test")
end
local a = string.dump(DumpTest)--将函数DumpTest转换成二进制码
print(a)
local b = loadstring(a)--loadstring(string)可以用来运行一段字符串代码.简单来说,就是把字符串转换成代码。
print(b)
b()
--string.dump可以实现函数序列化,函数可以传递了,甚至把函数传递到另一个进程都可以的。可以实现在其他作用域访问不同的地方的函数。
--更多的是做框架的时候用的功能,一般写逻辑代码应该用不到。
--]]
--string.find("原字符串", "要找的字符串"),在字符串s中找“XX”,返回两个值——起始索引和结尾索引
local a = "abcdefgh"
local tb = {"cde", "xyz", "gh", "hi"}
local tbResult = {}
for _, val in pairs(tb) do
local param1, param2 = string.find(a, val)
if param1 and param2 then
tbResult[#tbResult + 1] = string.sub(a, param1, param2)--提取出要找的字符串,并放到表tbResult里。
print(a .. "里有" .. val)
else
print(a .. "里没有" .. val)
end
end
--]]
--string.math("原字符串", "要找的字符串"),也是在字符串中搜索,但是注重的是模式匹配的那部分子字符串
--[[在字符串date中找出特定格式的信息,并输出。Example:
local date = "My birthday is 8/4/1991!"
local result = string.match(date, "%d+/%d+/%d+")
print(result)
--]]
--string.find着重在字符串里找完全一样的子字符串;string.math着重在字符串里找模式匹配的子字符串。
--string.gsub("原字符串", "要找的字符串", "希望替换成的字符串", n替换次数)不写替换次数的情况下会全部替换
--[[Example:将字符串“Lua is cute!”中的“u”依据条件换成其他的东东。
local s = string.gsub("Lua is cute!", "u", "XX")
print(s)
local m, n = string.gsub("Lua is cute!", "u", "XX", 1)
print(m, n)
print(string.gsub("Lua is cute!", "u", "XX"))
--实验证明,string.gsub会返回两个值 —— 替换后的字符串和替换执行次数。
--如果只想取替换后的字符串而不想要替换次数的话,用第一种写法。
--]]
--string.gmatch("原字符串", "需要的模式")。遍历到一个字符串中所有出现指定模式的地方。
--[[Example:输出一个字符串中包含多少个单词,并依次输出单词。
function Count(s)
local tbWords = {}
for w in string.gmatch(s, "%a+") do
tbWords[#tbWords + 1] = w
end
return tbWords
end
local a = "Lua is very very very cute!"
local tbWords = Count(a)
for _, val in pairs(tbWords) do
print(val)
end
print("一共有" .. #tbWords .. "个单词")
--]]
--string.reverse(字符串)。返回一个字符串的倒序排列
--[[
function ReverseTest(s)
return string.reverse(s)
end
local a = "abcdefg"
print(ReverseTest(a))
--]]