高速掌握Lua 5.3 —— 字符串库 (2)
Q:模式匹配字符串的相关函数?
A:
--[[ string.find(s, pattern [, init [, plain]])
在字符串"s"中查找第一个与匹配模式"pattern"相匹配的子串,
函数返回子串的開始位置和终止位置。假设未找到返回"nil"。
假设在"pattern"中定义了捕获,捕获物也会在之后依次返回。
"init"可指定从字符串"s"的什么位置開始查找,默觉得1。
"plain"指定是否以模式匹配的形式查找子串,假设"plain"为0,
那么将依据"pattern"的字面意思查找子串。默觉得非0值。]]
s = "Hello World! 123 %a+"
print(string.find(s, "l")) --> 3 3
print(string.find(s, "l", 6)) --> 10 10
print(string.find(s, "lll", 6)) --> nil
print(string.find(s, "%a+", 6)) --> 7 11
print(string.find(s, "%a+", 6, 0)) --> 18 20
-- 通过使用第三个參数能够实现查找字符串中全部匹配"pattern"的子串。
local b = 0
local e = 0
while true do
-- 从匹配位置的下一个位置開始继续查找。
b, e = string.find(s, "%a+", e + 1)
if b == nil then break end
io.write(string.format("%s, ", string.sub(s, b, e)))
--> Hello, World, a,
end
print()
--[[ string.gsub(s, pattern, repl [, n])
将字符串"s"中前"n"个与匹配模式"pattern"相匹配的子串替换为"repl",
"n"假设不指定,默认替换全部的匹配。
函数返回被替换后的字符串。以及替换的次数。
1、假设"repl"是一个字符串(当中能够使用捕获物),那么把这个字符串作为替换品。
特例,"%0"代表整个匹配。
2、假设"repl"是一个"table",每次匹配时都会用第一个捕获物作为键去查这张表。
假设"repl"是一个函数,则在每次匹配时都会以全部捕获物作为參数调用这个函数。
3、假设"pattern"中没有设定捕获。则默认捕获整个"pattern"。
4、假设"table"的查询结果或者函数的返回结果是一个字符串或是个数字时,
都将其作为替换品。而结果为"false"或"nil"时不作替换(即保留匹配前的原始串)。]]
print(string.gsub("Lua is cute", "cute", "great"))
--> Lua is great 1
print(string.gsub("all lii", "l", "x"))
--> axx xii 3
print(string.gsub("Lua is great", "perl", "tcl"))
--> Lua is great 0
print(string.gsub("hello world", "(%w+)", "%1 %1"))
--> hello hello world world 2
print(string.gsub("hello world", "%w+", "%0 %0", 1))
--> hello hello world 1
print(string.gsub("hello world from Lua", "(%w+)%s*(%w+)", "%2 %1"))
--> world hello Lua from 2
print(string.gsub("home = $HOME, user = $USER", "%$(%w+)", os.getenv))
--> home = /home/roberto, user = roberto
高速掌握Lua 5.3 —— 字符串库 (2)的更多相关文章
- Lua字符串库
1. 基础字符串函数: 字符串库中有一些函数非常简单,如: 1). string.len(s) 返回字符串s的长度: 2). string.rep(s,n) 返回字符串s重复n次的结 ...
- Lua字符串库(整理)
Lua字符串库小集 1. 基础字符串函数: 字符串库中有一些函数非常简单,如: 1). string.len(s) 返回字符串s的长度: 2). string.rep(s,n) 返回 ...
- Step By Step(Lua字符串库) (转)
1. 基础字符串函数: 字符串库中有一些函数非常简单,如: 1). string.len(s) 返回字符串s的长度: 2). string.rep(s,n) 返回字符串s重复n次的结 ...
- Lua 中的string库(字符串函数库)总结
(字符串函数库)总结 投稿:junjie 字体:[增加 减小] 类型:转载 时间:2014-11-20我要评论 这篇文章主要介绍了Lua中的string库(字符串函数库)总结,本文讲解了string库 ...
- Lua中字符串库中的几个重点函数
[前言] 在<Lua中的一些库(1)>中也说到了,要对string库的模式匹配进行单独的讲解.对于字符串的处理,对于任何语言的学习来说,都是一个难点,而且也是一个必会的知识点.给你一个字符 ...
- Lua中的字符串函数库
字符串库中的一些函数是非常简单的: string.len(s) 返回字符串s的长度:string.rep(s, n) 返回重复n次字符串s的串:你使用string.rep( ...
- Step By Step(Lua字符串库)
Step By Step(Lua字符串库) 1. 基础字符串函数: 字符串库中有一些函数非常简单,如: 1). string.len(s) 返回字符串s的长度: 2). string ...
- Lua中的一些库(1)
[数学库] 数学库(math)由一组标准的数学函数构成.这里主要介绍几个常用的函数,其它的大家可以自行百度解决. 三角函数(sin,cos,tan……)所有的三角函数都使用弧度单位,可以用函数deg( ...
- Lua中的一些库(2)
[前言] 在<Lua中的一些库(1)>这篇文章中,总结了一部分Lua中的库函数,一篇文章肯定是总结不完的,所以,就来一个<Lua中的一些库(2)>.希望大家能忍住.来吧. 操作 ...
随机推荐
- Moodle 中文 API 之 文件管理API
File API 文件管理 文件夹 1. 概述 2. 文件域 2.1 命名文件域 3. 提供文件给用户 4. 从用户那获取文件 5. 样例 5.1 浏览文件 5.2 移动文件 5.3 文件列表 5. ...
- 分治法(divide & conquer)与动态规划(dynamic programming)应用举例
动态规划三大重要概念:最优子结构,边界,状态转移公式(问题规模降低,如问题由 n 的规模降低为 n−1 或 n−2 及二者之间的关系): 0. 爬台阶 F(n)⇒F(n−1)+F(n−2) F(n−1 ...
- springmvc+shiro+freemarker实现的安全及权限管理
本文讲述了基于springmvc+shiro实现安全管理,shiro+freemarker实现权限验证. 首先我们从web.xml开始: <?xml version="1.0" ...
- 讨论:怎样加快android的开机时间
如题,近期项目须要,须要将android的开机时间大幅缩短,查了下网上资料,作用有限,望有处理过相关问题的兄弟姐妹參与讨论,给予不吝赐教,期待ing
- 步步为营(十五)搜索(一)DFS 深度优先搜索
前方大坑预警! 先讲讲什么是搜索吧. 有一天你去一个果园摘梨子,果农告诉你.有一棵树上有一个金子做的梨子,找到就是你的,你该怎么找? 地图例如以下: S 0 0 0 0 0 0 0 0 0 0 0 0 ...
- 9.12 Binder系统_Java实现_内部机制_Client端
Java实现中client端的RPC层(java实现)如何通过JNI来调用IPC层(C++实现)发送数据 TestServer通过addService向Service_manager注册的时候Test ...
- [Angular] Implementing A General Communication Mechanism For Directive Interaction
We have modal implement and now we want to implement close functionality. Becuase we use a structure ...
- Linux 下配置 Python IDE——Emacs
工欲善其事,必先利其器.Python作为高级语言,因为其简介.灵活已经被越来越多的程序员所青睐.在尝试了众多IDE之后,终于找到了自己的挚爱.废话少说,下面开始说一下如何在linux下安装配置Emac ...
- 【转载】C# winform操作excel(打开、内嵌)
本文转载自静待"花落<C# winform操作excel(打开.内嵌)> 说明:显示的excel是利用模板创建的 using System;using System.Coll ...
- log4cxx入门篇
log4cxx入门篇 先看官网:http://logging.apache.org/log4cxx/index.html 转载自:http://wenku.baidu.com/view/d88 ...