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