这些%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'