Lua字符串库(string库)学习笔记


本文向大家介绍Lua字符串库(string库)学习笔记,包括了Lua字符串库(string库)学习笔记的使用技巧和注意事项,需要的朋友参考一下

Lua 最强大的特性之一就是它的字符串处理能力,它支持字符格式化输出,具有可扩展的模式匹配查找功能,以及一些实用的字符操作,例如查询、截取、替换和删除等字符串操作,这些字符串操作函数都封装在一个名为 string 的模块里。

Lua 里的字符索引是从 1 开始,索引值也可以是负数,这种情况将被解释成向后索引,从字符串末尾开始算起。

下面是 Lua 5.2 提供的字符串操作函数:

byte

函数 string.byte 把字符串里的第 i 个字符转为 ASCII 编码,默认是输出第一个字符的编码(只有一个参数的话),用法:


string.byte (s [, i [, j]])

例子:


print(string.byte("abc")) //echo:97

print(string.byte("abc", 2))//echo:98

char

函数 string.char 是把一个 ASCII 编码转换为对应的字符,用法:


string.char (asc1, ...)

例子:


print(string.char(97)) //echo a

print(string.char(99, 100, 101)) //echo cde

dump

函数 string.dump 返回一个函数二进制形式的字符串,用法:


string.dump (function)

参数 function 是一个 Lua 函数:


function test()

    print("just a test")

end

print(string.dump(test))

函数 string.dump 实现了函数的序列化,函数可以很轻松的传递,并在其他作用域调用。函数 string.dump 出来的二进制字符串,可以用 load 函数反序列回来直接调用。


function test()

    print("just a test")

end

local sd = string.dump(test)

print(sd)

local ls = load(sd)

print(ls)

ls()

find

函数 string.find 查找字符串 s 里第一个符合查找字符 pattern 的位置,用法:


string.find (s, pattern [, init [, plain]])

如果找到了目标字符 pattern,则返回它的开始和结束位置:


start, end = string.find("just a test", "st")

print(start, end)

如果没有找到,则返回 nil:


print(string.find("just a test", "dhq.me"))

format

函数 string.format 用于把字符串格式化输出,用法:


string.format (formatstring, ···)


string.format 函数的第一个参数是用来指定字符串的格式,例如:


print(string.format("%s is %d", "ten", 10))

上面例子里的 %s 表示字符串,%d 表示数字,它们是 Lua 的格式化输出符号。

string.format 函数的用法跟 C 语言里的 printf 函数类似,例如它可以像 printf 那样输出指定位数的数字:


Pi = 3.1415926

print(string.format("Pi is %.2f", Pi))

Lua 的字符格式化输出符号列表:


.           所有字符

%a          字母

%c          控制符

%d          数字

%D          非数字

%l          小写字母

%p          标点符号

%s          字符串

%u          大写字母

%w          字母数字

%x          十六进制数

%z          用 0 表示的字符

gmatch

函数 string.gmatch 会返回一个迭代函数,尅通过该函数遍历到一个字符串 s 中所有出现指定匹配模式 pattern 的地方,用法:


string.gmatch (s, pattern)

例如下面是找出字符串 s 里的所有单词:


s = "just a test"

for w in string.gmatch(s, "%a+") do

    print(w)

end

gsub

函数 string.gsub 用于全局字符串替换,字符串 s 里满足匹配模式 pattern 格式的字符都会被替换成 repl 参数的值,用法:


string.gsub (s, pattern, repl [, n])

例如:


print(string.gsub("just a test", "st", "*"))

匹配模式 pattern 可以是一个正则:


s = "num is 1234567890"

print(string.gsub(s, "%d", "*"))

可在函数的最后加上一个可选参数 n,表示指定要替换的次数:


s = "sethook, setlocal, setmetatable, setupvalue, setuservalue"

print(string.gsub(s, "s%a+", "S", 2))

len

函数 string.len 用于返回字符串 s 的长度,用法:


string.len (s)

例子:


print(string.len("abcdefg"))

lower

函数 string.lower 用于把字符串 s 里的字母转为小写,用法:


string.lower (s)

例如:


print(string.lower("AbCdEfG"))

match

函数 string.match 用于查找字符串 s 里第一个匹配对模式 pattern 的值,并返回匹配值,用法:


string.match (s, pattern [, init])

上面参数 init 是可选, 表示查找过程的起点, 默认从 1 开始:


print(string.match("just a test", "test"))

参数 patter 可以是一个正则模式:


t = "today is 2003-5-31"

print(string.match(t, "%d+-%d+-%d+"))

如果 pattern 为空,则返回整个字符串;如果没匹配成功,则返回 nil。


print(string.match("abcdabcd", "a"))

rep

函数 string.rep 返回一个由分隔符 sep 隔开的重复(repeat)n 次字符 s 的字符串,用法:


string.rep (s, n [, sep])


默认的分隔符 sep 是空字符。


print(string.rep("repeat", 3))

reverse

函数 string.reverse 用于倒转一个字符串 s 的排序,用法:


string.reverse (s)

例如:


print(string.reverse("reverse"))

sub

函数 string.sub 用于从字符串 s 里截取一个从第 i 个字符到第 j 个字符间的子字符串,用法:


string.sub (s, i [, j])


例如:


print(string.sub("abcdefg", 2, 5))


参数 i 可以是负数,这种情况下,子串的位置从字符串 s 的最后开始算起:


print(string.sub("abcdefg", -4, -2))


参数 end 省略的话,则会返回从 i 到字符串末尾的子字符串:


print(string.sub("abcdefg", 3))

upper

函数 string.upper 用于把字符串 s 里的字母转为大写,用法:


string.upper (s)

例如:


print(string.upper("AbCdEfG"))