这些
%s
和
%d
之间区别的核心如下:
%s
告诉格式化程序在参数上调用
str()
函数,由于我们根据定义强制使用字符串,因此
%s
本质上只是执行
str(arg)
。
另一方面,
%d
在调用
str()
之前先调用参数上的
int()
,就像
str(int(arg))
一样,这将导致
int
强制和
str
强制。
例如,我可以将十六进制值转换为十进制,
>>> '%d' % 0x15
'21'
复制
或者截断一个浮点数。
>>> '%d' % 34.5
'34'
复制
但如果参数不是数字,该操作将引发异常。
>>> '%d' % 'thirteen'
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: %d format: a number is required, not str
复制
因此,如果其目的只是调用
str(arg)
,那么
%s
就足够了,但是如果您需要额外的格式化(比如格式化浮点小数位)或其他强制,那么就需要其他的格式符号。
使用
f-string
表示法时,如果省略了格式化程序,则默认值为
str
。
>>> a = 1
>>> f'{a}'
'1'
>>> f'{a:d}'
'1'
>>> a = '1'
>>> f'{a:d}'
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: Unknown format code 'd' for object of type 'str'
复制
string.format
也是如此;默认值为
str
。
>>> a = 1
>>> '{}'.format(a)
'1'
>>> '{!s}'.format(a)
'1'
>>> '{:d}'.format(a)
'1'