我不明白%s
和%d
是做什么的以及它们是如何工作的。
发布于 2010-11-27 06:36:49
它们用于格式化字符串。%s
充当字符串的占位符,而%d
充当数字的占位符。它们的关联值是使用%
运算符通过元组传入的。
name = 'marcog'
number = 42
print '%s %d' % (name, number)
将打印marcog 42
。请注意,name是字符串(%s),number是整数(%d表示小数)。
详情请参见https://docs.python.org/3/library/stdtypes.html#printf-style-string-formatting。
在Python 3中,示例如下:
print('%s %d' % (name, number))
发布于 2010-11-27 06:37:44
%s
用作要注入格式化字符串的字符串值的占位符。
%d
用作数值或十进制值的占位符。
例如(对于python 3)
print ('%s is %d years old' % ('Joe', 42))
将输出
Joe is 42 years old
发布于 2019-05-31 00:23:42
这些都是信息丰富的答案,但没有一个真正抓住%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'
https://stackoverflow.com/questions/4288973
复制相似问题