string.format()函数用来生成具有特定格式的字符串,这个函数有两个参数,第一个参数为格式化串:由指示符和控制格式的字符组成。第二个参数是对应格式中每个代号的各种数据.
格式字符串可能包含以下的转义码:
%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, i, f, ...).
print(string.format("pi = %.4f", PI))
--> pi = 3.1416
d = 5; m = 11; y = 1990
print(string.format("%02d/%02d/%04d", d, m, y))
--> 05/11/1990
tag, title = "h1", "a title"
print(string.format("<%s>%s</%s>", tag, title, tag))
--> <h1>a title</h1>
第一个例子,%.4f代表小数点后面有4位小数的浮点数。第二个例子%02d代表以固定的两位显示十进制数,不足的前面补0。而%2d前面没有指定0,不足两位时会以空白补足。对于格式串部分指示符得详细描述清参考lua手册,或者参考C手册,因为Lua调用标准C的printf函数来实现最终的功能。
以下是一些例子
- print(string.format("%%c: %c", 83)) --输出S
- print(string.format("%+d", 17.0)) --输出+17
- print(string.format("%05d", 17) ) --输出00017
- print(string.format("%o", 17) ) --输出21
- print(string.format("%u", 3.14) ) --输出3
- print(string.format("%x", 13) ) --输出d
- print(string.format("%X", 13) ) --输出D
- print(string.format("%e", 1000) ) --输出1.000000e+03
- print(string.format("%E", 1000) ) --输出1.000000E+03
- print(string.format("%6.3f", 13) ) --输出13.000
- print(string.format("%q", "One\nTwo") ) --输出"One\
- print(string.format("%s", "monkey") ) --输出monkey
- print(string.format("%10s", "monkey") ) --输出monkey
- print(string.format("%5.3s", "monkey") ) --输出mon
- string.format("{'playid':'%d','commodityid':'%d','price':'%d','price_type':'%d','num':'%d','activity':'%d' ,'time':'%d'}",pPlayer:GetGUID(),nItemID,(paymoney/nItemNum),nMoneyType,nItemNum,1,os.time())