LUA string库详解

LUA string库详解,第1张

概述1. string库中所有的字符索引从前往后是1,2,...;从后往前是-1,-2,... 2. string库中所有的function都不会直接 *** 作字符串,而是返回一个结果   string.byte(string [,pos]):返回第pos个字符的整数表示形式.如a为97. string.char(i1,i2...):i1,i2为整型,将i1,i2..等转化为对应的字符然后连接成字符串,并返

1. string库中所有的字符索引从前往后是1,2,...;从后往前是-1,-2,...
2. string库中所有的function都不会直接 *** 作字符串,而是返回一个结果

 

string.byte(string [,pos]):返回第pos个字符的整数表示形式.如a为97.

string.char(i1,i2...):i1,i2为整型,将i1,i2..等转化为对应的字符然后连接成字符串,并返回.如i1=97则返回a.

string.dump(functoin):返回一个参数函数的2进制代码.(疑问)

string.find(s,pattern [,init [,plain]]):查找pattern在s中的位置,返回pattern在s中的开始位置和结束位置.init是开始查找的位置.plain未知.

string.len(s):返回字符串的长度.

string.lower(s):变小写.

string.upper(s):变大写.

string.rep(s,n):将s拷贝n份,并连接起来,返回.

string.sub(s,i [,j]):取s中从i开始到j为止的自字符串.默认j为长度.-i表示倒数.

例如:

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) <==返回"abc"
string.format(fmt,...)返回一个类似printf的格式化字符串

string.find(s,pattern,pos) 
第1个参数:源字符串
第2个参数:待搜索之模式串
第3个参数:A hint, 从pos位置开始搜索
找到匹配返回:匹配串开始和结束的位置,否则返回nil

例如:
s = "[abc]"
string.len(s)        <==

string.gsub(s,reps)
第1个参数:源字符串
第2个参数:待替换之模式串
第3个参数:替换为reps
将s中所有符合pattern的字串替换为reps,返回结果串+匹配数

print(string.gsub("hello,world","o","a"))       <== hella,warld        2

gsub也可以用拷贝捕获技巧
print(string.gsub("hello,"(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,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简单的模式串
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,"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代表第几个捕获的拷贝。

总结

以上是内存溢出为你收集整理的LUA string库详解全部内容,希望文章能够帮你解决LUA string库详解所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1249199.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-07
下一篇 2022-06-07

发表评论

登录后才能评论

评论列表(0条)

保存