--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))
--]]