--string.len(s)
--返回字符串s的长度
--string.rep(s,n)
--返回重复n次字符串s的串,你使用string.rep("a",2^20)可以创建一个1M bytes的字符串(比如,为了测试需要);
--string.lower(s)
--将s中的大写字母转换成小写(string.upper将小写转换成大写).如果你想不关心大小写对一个数组进行排序的话,你可以这样:
--string.upper(s)
--将s中的小写字母转换成大写
--string.sub(s,i,j)
--函数截取字符串s的从第i个字符到第j个字符之间的串.Lua中,字符串的第一个字符索引从1开始.你也可以使用负索引,负索引从字符串的结尾向前计数:-1指向最后一个字符,-2指向倒数第二个,以此类推.
--所以,
--string.sub(s,1,j)返回字符串s的长度为j的前缀;
--string.sub(s,j,-1)返回从第j个字符开始的后缀.
--如果不提供第3个参数,默认为-1,因此我们将最后一个调用写为string.sub(s,j);
--string.sub(s,2,-2)返回去除第一个和最后一个字符后的子串.
s = "[in brackets]"print(string.sub(s,-2)) --> in bracketss = string.sub(s,-2)
--string.char函数和string.byte函数用来将字符在字符和数字之间转换.
--string.char获取0个或多个整数,将每一个数字转换成字符,然后返回一个所有这些字符连接起来的字符串.
--string.byte(s,i)将字符串s的第i个字符的转换成整数;第二个参数是可选的,缺省情况下i=1.
print(string.char(97)) --> ai = 99; print(string.char(i,i+1,i+2)) --> cdeprint(string.byte("abc")) --> 97print(string.byte("abc",2)) --> 98print(string.byte("abc",-1)) --> 99
--string.format()函数来生成具有特定格式的字符串,
--函数的第一个参数是格式(formatstring),之后是对应格式中每个代号的各种数据. 由于格式字符串的存在,使得产生的长字符串可读性大大提高了.
--这个函数的格式很像C语言中的printf().函数string.format在用来对字符串进行格式化的时候,特别是字符串--输出,是功能强大的工具.
--这个函数有两个参数,你完全可以照C语言的printf来使用这个函数.
--第一个参数为格式化串:由指示符和控制格式的字符组成.指示符后的控制格式的字符可以为:十进制'd';十六进制'x';八进制'o';浮点数'f';字符串's'.在指示符'%'和控制格式字符之间还可以有其他的选项:用来控制更详细的格式,比如一个浮点数的小数的位数:
--[[
%c - 接受一个数字,并将其转化为ASCII码表中对应的字符
%d,%i - 接受一个数字并将其转化为有符号的整数格式
%o - 接受一个数字并将其转化为八进制数格式
%u - 接受一个数字并将其转化为无符号整数格式
%x - 接受一个数字并将其转化为十六进制数格式,使用小写字母
%X - 接受一个数字并将其转化为十六进制数格式,使用大写字母
%e - 接受一个数字并将其转化为科学记数法格式,使用小写字母e
%E - 接受一个数字并将其转化为科学记数法格式,使用大写字母E
%f - 接受一个数字并将其转化为浮点数格式
%g(%G) - 接受一个数字并将其转化为%e(%E,对应%G)及%f中较短的一种格式
%q - 接受一个字符串并将其转化为可安全被Lua编译器读入的格式
%s - 接受一个字符串并按照给定的参数格式化该字符串
为进一步细化格式,可以在%号后添加参数. 参数将以如下的顺序读入:
(1) 符号: 一个+号表示其后的数字转义符将让正数显示正号. 默认情况下只有负数显示符号.
(2) 占位符: 一个0,在后面指定了字串宽度时占位用. 不填时的默认占位符是空格.
(3) 对齐标识: 在指定了字串宽度时,默认为右对齐,增加-号可以改为左对齐.
(4) 宽度数值
(5) 小数位数/字串裁切: 在宽度数值后增加的小数部分n,若后接f(浮点数转义符,如%6.3f)则设定该浮点数的小数只保留n位,若后接s(字符串转义符,如%5.3s)则设定该字符串只显示前n位.
在这些参数的后面则是上述所列的转义码类型(c,d,f,...).
]]
d = 5; m = 11; y = 1990print(string.format("%02d/%02d/%04d",m,y))--%02d代表以固定的两位显示十进制数,不足的前面补0.而%2d前面没有指定0,不足两位时会以空白补足 --> 05/11/1990tag,Title = "h1","a Title"print(string.format("<%s>%s</%s>",tag,Title,tag)) --> <h1>a Title</h1>string.format("%%c: %c",83) --输出Sstring.format("%+d",17.0) --输出+17string.format("%05d",17) --输出00017string.format("%o",17) --输出21string.format("%u",3.14) --输出3string.format("%x",13) --输出dstring.format("%X",13) --输出Dstring.format("%e",1000) --输出1.000000e+03string.format("%E",1000) --输出1.000000E+03string.format("%6.3f",13) --输出13.000string.format("%q","One\nTwo") --输出"One\string.format("%s","monkey") --输出monkeystring.format("%10s","monkey") --输出 monkeystring.format("%5.3s","monkey") --输出 mon
--string.gsub(s,pattern,reps[,limitNumber]) 将s中所有符合pattern的字串替换为reps,返回结果串+匹配数
--s 源字符串
--待替换的字符模式
--替换为reps
--limitNumber 限制替换的次数
print(string.gsub("hello,world","o","a")) -- hella,warld 2--gsub也可以用拷贝捕获技巧print(string.gsub("hello,"(o)","%1-%1")) -- hello-o,wo-orld 2print(string.gsub("hello Lua","(.)(.)","%2%1")) -- ehll oula 4 每2个字符进行位置调换function trim (s) return (string.gsub(s,"^%s*(.-)%s*$","%1")) end --注意匹配数用括号丢弃
--string.gsub(s,func)
--func 对找到的匹配 *** 作,并传出替换值
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=bprint(iter()) --<== c=d
--string.match(s,d) --与string.find类似 但是返回匹配的子串
--s 源字符串
--d 目标字符串或者模式
print(string.match("hello world","hello")) --hellolocal today="today is 19/2/2001"print(string.match(today,"%d+/%d+/%d"))--19/2/2001
--string.gmatch() --返回一个迭代函数 可以遍历出现的目标字符串
总结以上是内存溢出为你收集整理的LUA之string的使用全部内容,希望文章能够帮你解决LUA之string的使用所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)