博客
关于我
lua正则替换_Lua字符串模式匹配函数小结
阅读量:740 次
发布时间:2019-03-22

本文共 1680 字,大约阅读时间需要 5 分钟。

模式匹配函数是Lua字符串库中功能最强大的部分。与其他脚本语言不同,Lua不使用POSIX规范的正则表达式进行模式匹配。这种选择主要是出于程序大小的考虑,Lua的实现仅用了500行代码,而POSIX规范的正则表达式实现需要4000行左右。尽管如此,Lua的模式匹配功能非常强大,并且包含了一些标准POSIX模式匹配无法实现的功能。

以下是Lua字符串库中常用的模式匹配函数及其用途:

1. string.find:用于在字符串中搜索模式并返回匹配位置

string.find(str, pattern, init)函数用于在目标字符串中搜索指定模式。函数返回匹配项的开始和结束索引。如果没有找到匹配项,返回nil。第三个参数init指定起始位置,用于继续搜索后的位置。

示例:

s = "hello world"

pos = string.find(s, "hello")

--> pos: 1 5

pos = string.find(s, "world")

--> pos: 7 11

pos = string.find(s, "l")

--> pos: 3 3

pos = string.find(s, "lll")

--> nil

2. string.gsub:全局字符串替换函数

string.gsub(str, pattern, repl, n)函数用于对源字符串中的所有匹配项进行替换。返回替换后的字符串、替换次数以及可能的替换结果。

示例:

s = "hello world"

s = string.gsub(s, "hello", "hi")

--> hi world

s = string.gsub("Lua is cute", "cute", "great")

--> Lua is great

s = string.gsub("all lii", "l", "x", 1)

--> axl lii

3. string.gmatch:返回迭代器函数

string.gmatch(str, pattern)函数返回一个迭代器,用于遍历字符串中的所有匹配项。该函数在Lua中非常有用,可以用来逐个处理匹配结果。

示例:

s = "hello world from Lua"

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

print(w)

end

4. string.match:查找第一个匹配项

string.match(str, pattern, init)函数用于查找字符串中的第一个匹配项。返回匹配项的捕获结果或nil。如果使用第三个参数init,可以指定起始位置。

示例:

pos = string.match("abcdaef", "a")

--> a

5. string.reverse:字符串反转函数

string.reverse(str)函数用于返回一个字符串的倒序排列。

示例:

reversed_str = string.reverse("abcde")

--> edcba

6. string.dump:二进制代码函数

string.dump(function)函数用于返回指定函数的二进制代码。该函数仅适用于没有上值的Lua函数。

Lua的模式匹配功能非常强大,支持多种模式修饰符和字符类。以下是常用的模式修饰符:

- %+:匹配一个或多个重复的字符

- *:匹配零个或多个重复的字符

- -:匹配零个或多个重复的字符(最短匹配)

- ?:匹配零个或一个重复的字符

这些修饰符可以与字符类组合使用,例如:

%d+:匹配一个或多个数字

%w+:匹配一个或多个字母或数字

%s*:匹配零个或多个空白字符

对于更复杂的匹配需求,可以使用括号创建字符集合,例如:

%[a-z]:匹配一个小写字母

%[^%s]:匹配一个非空白字符

此外,Lua支持使用转义字符来处理特殊字符,例如:

'%%':匹配一个 '%' 字符

''%.'':匹配一个 '.' 字符

这些特性使得Lua的模式匹配功能非常灵活和强大。

转载地址:http://pluwk.baihongyu.com/

你可能感兴趣的文章
Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
查看>>
Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
查看>>
Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
查看>>
Mysql 学习总结(89)—— Mysql 库表容量统计
查看>>
mysql 实现主从复制/主从同步
查看>>
mysql 审核_审核MySQL数据库上的登录
查看>>
mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
查看>>
mysql 导入导出大文件
查看>>
mysql 将null转代为0
查看>>
mysql 常用
查看>>
MySQL 常用列类型
查看>>
mysql 常用命令
查看>>
Mysql 常见ALTER TABLE操作
查看>>
mysql 往字段后面加字符串
查看>>
mysql 快速自增假数据, 新增假数据,mysql自增假数据
查看>>
Mysql 报错 Field 'id' doesn't have a default value
查看>>
MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
查看>>
mysql 排序id_mysql如何按特定id排序
查看>>
Mysql 提示:Communication link failure
查看>>
mysql 插入是否成功_PDO mysql:如何知道插入是否成功
查看>>