我最早学习的是C++语言,对于C风格的这种字符串格式化方式不熟悉,转到Python之后觉得这种方式可以很方便地在字符串中插入变量,于是去搜索了python的官方文档,找到了一个关于字符串格式化的页面。
这种格式化方法的使用方式是format % values
,其中format是字符串,value就是要插入的值。在format中,需要用值替换的位置用转换说明符(conversion specifier)进行占位,转换说明符是一组以%开头的字符,例如:
>>> age = 17
>>> string = "Tom is %s years old."
>>> print(string % age)
Tom is 17 years old.
在上例中,%s
即转换说明符,s
表示将value转换成字符串类型,python会在内部调用str(age)
,并把返回的字符串"17"
插入到原来%s
所在的位置。当然,对于上例中value是数值的情况,也可以使用整型类型说明符d
或i
,二者效果相同:
>>> print("Tom is %d years old." % age)
Tom is 17 years old.
>>> print("Tom is %i years old." % age)
Tom is 17 years old.
如果format只需要一个参数,就像上例中的那样,那么后面的value必须是一个非元组对象(non-tuple object)。如果format需要多个参数,value就得是一个含有恰好满足format参数数量个元素的元组:
>>> age2 = 16
>>> print("Tom is %s years old \
while his brother Bob is %s years old." % (age, age2))
Tom is 17 years old while his brother Bob is 16 years old.
使用字典作为value也是可以的,这种方法必须在format中写明字典的键,并用括号括起来:
>>> print("Tom is %(Tom)s years old \
while his brother Bob is %(Bob)s years old." % {'Tom': age, 'Bob': age2})
Tom is 17 years old while his brother Bob is 16 years old.
format中的转换说明符一共由7部分构成,按照排列顺序依次是:
"%" 映射键 转换标记 最小字段宽度 精度 长度限定 转换类型
其中仅有起始的百分号%和末尾的转换类型是必须的,中间的5个部分都是可选参数。映射键需要使用小括号括起来,如上例中的字典键。
转换标记有以下几种:
转换标记 | 说明 |
---|---|
# | 转换将会使用下方定义的替代形式 |
0 | 对于数值形式的转换,用 "0" 补齐空位 |
- | 居左 (如果与 "0" 同时出现,将会覆盖 "0"). |
(空格) 转换有符号的值时,在正数前加上一个空格 | |
+ | 转换有符号的值时,在正数前加上 "+" (会覆盖空格标记) |
这些符号常和精度一起使用,精度既可以指定整数也可以指定小数,指定小数时需要加上小数点"."
:
>>> print("Tom is %3d years old." % age) # 整数占三位
Tom is 17 years old.
>>> print("Tom is % d years old." % age) # 加空格
Tom is 17 years old.
>>> print("Tom is %03d years old." % age) # 用0补齐空位
Tom is 017 years old.
>>> print("Tom is %-3d years old." % age) # 居左
Tom is 17 years old.
>>> print("Tom is %+d years old." % age) # 添加+号
Tom is +17 years old.
>>> print("Tom is %+.2f years old." % age) # 指定小数位数
Tom is +17.00 years old.
转换类型如下表所示:
转换类型 | 说明 |
---|---|
d | 十进制有符号整型 |
i | 十进制有符号整型 |
o | 无符号八进制 |
u | 无符号十进制 |
x | 无符号十六进制(小写) |
X | 无符号十六进制(大写) |
e | 浮点指数格式(小写) |
E | 浮点指数格式(大写) |
f | 十进制浮点格式 |
F | 十进制浮点格式 |
g | 若指数大于-4或小于精度则于"e"相同,其他情况为"f" |
G | 若指数大于-4或小于精度则于"E"相同,其他情况为"F" |
c | 单字符(接受整型或单字符的字符串类型) |
r | 字符串(使用repr()转换python对象) |
s | 字符串(使用str()转换python对象) |