字符串具有一种特殊的内置操作:使用 %
(取模) 运算符。 这也被称为字符串的 格式化 或 插值 运算符。 对于 format % values
(其中 format 为一个字符串),在 format 中的 %
转换标记符将被替换为零个或多个 values 条目。 其效果类似于在 C 语言中使用 sprintf()
。
如果 format 要求一个单独参数,则 values 可以为一个非元组对象。 5 否则的话,values 必须或者是一个包含项数与格式字符串中指定的转换符项数相同的元组,或者是一个单独映射对象(例如字典)。
转换标记符包含两个或更多字符并具有以下组成,且必须遵循此处规定的顺序:
'%'
字符,用于标记转换符的起始。映射键(可选),由加圆括号的字符序列组成 (例如
(somename)
)。转换旗标(可选),用于影响某些转换类型的结果。
最小字段宽度(可选)。 如果指定为
'*'
(星号),则实际宽度会从 values 元组的下一元素中读取,要转换的对象则为最小字段宽度和可选的精度之后的元素。精度(可选),以在
'.'
(点号) 之后加精度值的形式给出。 如果指定为'*'
(星号),则实际精度会从 values 元组的下一元素中读取,要转换的对象则为精度之后的元素。长度修饰符(可选)。
转换类型。
当右边的参数为一个字典(或其他映射类型)时,字符串中的格式 必须 包含加圆括号的映射键,对应 '%'
字符之后字典中的每一项。 映射键将从映射中选取要格式化的值。 例如:
在此情况下格式中不能出现 *
标记符(因其需要一个序列类的参数列表)。
转换旗标为:
旗标 | 含意 |
---|---|
| 值的转换将使用“替代形式”(具体定义见下文)。 |
| 转换将为数字值填充零字符。 |
| 转换值将靠左对齐(如果同时给出 |
| (空格) 符号位转换产生的正数(或空字符串)前将留出一个空格。 |
| 符号字符 ( |
可以给出长度修饰符 (h
, l
或 L
),但会被忽略,因为对 Python 来说没有必要 -- 所以 %ld
等价于 %d
。
转换类型为:
转换符 | 含意 | 备注 |
---|---|---|
| 有符号十进制整数。 | |
| 有符号十进制整数。 | |
| 有符号八进制数。 | (1) |
| 过时类型 -- 等价于 | (6) |
| 有符号十六进制数(小写)。 | (2) |
| 有符号十六进制数(大写)。 | (2) |
| 浮点指数格式(小写)。 | (3) |
| 浮点指数格式(大写)。 | (3) |
| 浮点十进制格式。 | (3) |
| 浮点十进制格式。 | (3) |
| 浮点格式。 如果指数小于 -4 或不小于精度则使用小写指数格式,否则使用十进制格式。 | (4) |
| 浮点格式。 如果指数小于 -4 或不小于精度则使用大写指数格式,否则使用十进制格式。 | (4) |
| 单个字符(接受整数或单个字符的字符串)。 | |
| 字符串(使用 | (5) |
| 字符串(使用 | (5) |
| 字符串(使用 | (5) |
| 不转换参数,在结果中输出一个 |
注释:
此替代形式会在第一个数码之前插入标示八进制数的前缀 (
'0o'
)。此替代形式会在第一个数码之前插入
'0x'
或'0X'
前缀(取决于是使用'x'
还是'X'
格式)。此替代形式总是会在结果中包含一个小数点,即使其后并没有数码。
小数点后的数码位数由精度决定,默认为 6。
此替代形式总是会在结果中包含一个小数点,末尾各位的零不会如其他情况下那样被移除。
小数点前后的有效数码位数由精度决定,默认为 6。
如果精度为
N
,输出将截短为N
个字符。参见 PEP 237。
由于 Python 字符串显式指明长度,%s
转换不会将 '\0'
视为字符串的结束。
在 3.1 版更改: 绝对值超过 1e50 的 %f
转换不会再被替换为 %g
转换。