string.format()函数的用法

本文详细介绍Lua语言中string.format()函数的使用方法,包括基本语法、格式控制符及其特殊用法,并通过实例演示如何进行字符串格式化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

string.format()函数的用法

lua中有很多字符串操作的函数,string.format()就是其中的一个,顾名思义,format是格式化的意思,则string.format()功能就是格式化一个字符串。
   
我们知道lua中可以用".."连接字符串,可以起到一部分格式化字符串的作用,但是如果字符串较长或者有特殊的格式转换操作(如十六进制转换),用".."就会很繁琐且可读性差。用string.format()就是一个很好的解决方案。

 

函数定义
string.format() 第一个参数为字符串格式,后面的参数可以任意多个,用于填充第一个参数中的格式控制符,最后返回完整的格式化后的字符串。
   
格式控制符以%开头,常用的有以下几种 
%s      -  接受一个字符串并按照给定的参数格式化该字符串
%d    - 接受一个数字并将其转化为有符号的整数格式
%f      -  
接受一个数字并将其转化为浮点数格式(小数),默认保留6位小数,不足位用0填充
%x    接受一个数字并将其转化为小写的十六进制格式
%X    接受一个数字并将其转化为大写的十六进制格式

示例:

1.  str = string.format("字符串:%s\n整数:%d\n小数:%f\n十六进制数:%X","qweqwe",1,0.13,348)

2.  print(str)

输出结果:

1.  字符串:qweqwe

2.  整数:1

3.  小数:0.130000

4.  十六进制数:15C

5.   

 

%X的特殊用法
%08X      中间的第2个数字格式化成多少位,第1个数字表示不足位数时的填充数,通常用0填充。
例如:

1.  str =string.format("0x%08X",348)

2.  print(str)

前面的0x只是个普通的字符串,可有可无,因为我们一般在十六进制数前面加上0x来表明这是一个十六进制数,所以这里才加了个0x,没有其他特殊意义。
输出结果:

1.  0x0000015C


%x的特殊用法与%X一样


%f的特殊用法
%0.3f     中的小数点右边的数字表示小数点后面保留多少位,小数点前面的数字表示位数不足时的填充数,通用用0填充。
例如:
格式化一个小数,保留2位小数

1.  str =string.format("%0.2f",34.2344)

2.  print(str)

 

输出结果:

1.  34.23


更多用法
    
   前面是常用的格式控制符,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,...).

1.  <font face="Verdana, Arial,Helvetica, sans-serif">print(string.format("pi = %.4f", PI))

2.        --> pi= 3.1416

3.  d = 5; m = 11; y = 1990

4.  print(string.format("%02d/%02d/%04d",d, m, y))

5.         --> 05/11/1990

6.  tag, title = "h1", "atitle"

7.  print(string.format("<%s>%s</%s>",tag, title, tag))

8.         --> <h1>a title</h1></font>


第一个例子,%.4f代表小数点后面有4位小数的浮点数。第二个例子%02d代表以固定的两位显示十进制数,不足的前面补0。而%2d前面没有指定0,不足两位时会以空白补足。对于格式串部分指示符得详细描述清参考lua手册,或者参考C手册,因为Lua调用标准Cprintf函数来实现最终的功能。

以下是一些例子:

1.  <fontface="Courier">string.format("%%c: %c", 83)           输出S

2.  string.format("%+d",17.0)              输出+17

3.  string.format("%05d",17)               输出00017

4.  string.format("%o",17)                输出21

5.  string.format("%u",3.14)               输出3

6.  string.format("%x",13)                输出d

7.  string.format("%X",13)                输出D

8.  string.format("%e",1000)               输出1.000000e+03

9.  string.format("%E",1000)               输出1.000000E+03

10. string.format("%6.3f",13)              输出13.000

11. string.format("%q","One\nTwo")         输出"One\

12.                                       Two"

13. string.format("%s","monkey")           输出monkey

14. string.format("%10s","monkey")         输出    monkey

15. string.format("%5.3s","monkey")        输出  mon</font>

 


### Lua 中 `string.format` 函数详解 #### 功能描述 `string.format()` 是用于格式化字符串的强大工具,在 Lua 编程中非常常用。此函数允许开发者通过指定格式来构建复杂的字符串表达,从而提高代码的可读性和维护性[^1]。 #### 基本语法 该方法遵循 C 语言中的 printf 家族风格,其基本调用形式如下: ```lua formatted_string = string.format(formatstring, ...) ``` 这里的 `formatstring` 表示格式控制串,而后面的参数则是要被插入到格式串相应位置的实际数据项[^2]。 #### 格式说明符 为了实现不同类型的数值或字符序列按照特定的方式显示出来,`string.format()` 支持多种格式说明符,常见的包括但不限于: - `%s`: 字符串类型; - `%d`, `%i`: 十进制整数; - `%o`: 八进制无符号整数; - `%u`: 十六进制无符号整数(小写字母); - `%X`: 十六进制无符号整数(大写字母); - `%f`: 浮点数; - `%%`: 输出百分号本身; 这些占位符可以在模板字符串里按需组合使用,并且可以通过附加修饰符来自定义宽度、精度等属性。 #### 实际应用案例 下面给出几个具体的例子来展示如何利用 `string.format()` 来创建更加灵活多变的文字输出效果: ```lua -- 将两个数字相加并以固定两位小数的形式打印结果 print(string.format("%.2f + %.2f = %.2f", 3.14159, 2.71828, 3.14159 + 2.71828)) -- 把当前时间戳转化为易于理解的人类友好型日期表示法 local now = os.time() print(string.format("今天的日期是:%Y-%m-%d", os.date("*t", now))) -- 组合多个变量成一句话 name = "Alice" age = 30 city = "Beijing" message = string.format("%s is %d years old and lives in %s.", name, age, city) print(message) -- 转换为十六进制颜色码 color_rgb = {r=255,g=165,b=0} hex_color = string.format("#%02X%02X%02X", color_rgb.r, color_rgb.g, color_rgb.b) print(hex_color) ``` 上述实例不仅展示了基础的功能特性,还体现了当面对复杂场景时,借助于适当的选择和配置选项能够达到事半功倍的效果。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值