这些%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'版权声明:本文为weixin_44419929原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。