Python __ format()函数

作用:格式化输出格式

基础使用

使用{}用作占位符,花括号里面可以包含名称,还可以包含有关如何对相应的值进行转换和格式设置的信息。

看代码吧。

使用名称/索引

#在最简单的情况下,替换字段没有名称或将索引用作名称。
>>> "{}, {} and {}".format("first", "second", "third")
'first, second and third'
#有了索引,就无需像上面这样按顺序排列。
>>> "{3} {0} {2} {1} {3} {0}".format("be", "not", "or", "to")
'to be or not to be'
# 命名字段的工作原理与你预期的完全相同。
>>> from math import pi
>>> "{name} is approximately {value}.".format(value=3.14, name="π")
'π is approximately 3.14.'

最后,在Python 3.6中,如果变量与替换字段同名,还可使用一种简写。在这种情况下,可使用f字符串——在字符串前面加上f。

>>> from math import e
>>> f"Euler's constant is roughly {e}."
"Euler's constant is roughly 2.718281828459045."

在这里,创建最终的字符串时,将把替换字段e替换为变量e的值。
这与下面这个更明确一些的表达式等价:

>>> "Euler's constant is roughly {e}.".format(e=e)
"Euler's constant is roughly 2.718281828459045."

完整版

替换字段。替换字段由如下部分组成,其中每个部分
都是可选的。

  1. 字段名: 索引或标识符
    指出要设置哪个值的格式并使用结果来替换该字段。除指定值外,还可指定值的特定部分,如列表的元素。

  2. 转换标志: 跟在叹号后面的单个字符。 当前支持的字符包括r(表示repr)、s(表示str)和a(表示ascii)。
    如果你指定了转换标志,将不使用对象本身的格式设置机制,而是使用指定的函数将对象转换为字符串,再做进一步的格式设置。

  3. 格式说明符: 跟在冒号后面的表达式 (这种表达式是使用微型格式指定语言表示的)。格式说明符让我们能够详细地指定最终的格式。
    包括格式类型(如字符串、浮点数或十六进制数),字段宽度和数的精度,如何显示符号和千位分隔符,以及各种对齐和填充方式。

下面详细介绍其中的一些要素。

替换字段名

在最简单的情况下,只需向format提供要设置其格式的未命名参数,并在格式字符串中使用未命名字段。此时,将按顺序将字段和参数配对。

还可给参数指定名称/索引,这种参数将被用于相应的替换字段中。你可混合使用这两种方法。
注意:不能同时使用手工编号和自动编号,因为这样很快会变得混乱不堪。

>>> "{foo} {} {bar} {}".format(1, 2, bar=4, foo=3)
'3 1 4 2'

>>> "{foo} {1} {bar} {0}".format(1, 2, bar=4, foo=3)
'3 2 4 1'

基本转换

可以提供一个转换标志,指定将传入的数据其视为哪种类型。
比如:

>>> print("{pi!s} {pi!r} {pi!a}".format(pi="π"))
π 'π' '\u03c0'

上述三个标志(s、r和a)指定分别使用str、repr和ascii进行转换。
函数str通常创建外观普通的字符串版本(这里没有对输入字符串做任何处理)。
函数repr尝试创建给定值的Python表示(这里是一个字符串字面量)。
函数ascii创建只包含ASCII字符的表示。

例如,你可能提供一个整数,但将其作为小数进行处理。为此可在格式说明(即冒号后面)使用字符f(表示定
点数)。

>>> "The number is {num}".format(num=42)
'The number is 42'
>>> "The number is {num:f}".format(num=42)
'The number is 42.000000'
# 也可以将其作为二进制数进行处理。
>>> "The number is {num:b}".format(num=42)
'The number is 101010'
类型 含义
s 保持字符串的格式不变,这是默认用于字符串的说明符
d 将整数视为十进制数进行处理,这是整数默认使用的说明符
b 将整数表示为二进制数
c 将整数解读为Unicode码点
f 将小数表示为定点数
F 与f相同,但对于特殊值(nan和inf),使用大写表示
o 将整数表示为八进制数
x 将整数表示为十六进制数并使用小写字母
X 与x相同,但使用大写字母
% 将数表示为百分比值(乘以100,按说明符f设置格式,再在后面加上%)
e 使用科学表示法来表示小数(用e来表示指数)
E 与e相同,但使用E来表示指数
g 自动在定点表示法和科学表示法之间做出选择。这是默认用于小数的说明符,但在默认情况下至少有1位小数 自动在定点表示法和科学表示法之间做出选择。这是默认用于小数的说明符,但在默认情况下至少有1位小数
G 与g相同,但使用大写来表示指数和特殊值
n 与g相同,但插入随区域而异的数字分隔符

宽度、精度和千位分隔符

设置浮点数(或其他更具体的小数类型)的格式时,默认在小数点后面显示6位小数,并根据需要设置字段的宽度,而不进行任何形式的填充。

当然我们可根据需要在格式说明中指定宽度和精度。
宽度是使用整数指定的,如下所示:

>>> "{num:10}".format(num=3)
' 3'
>>> "{name:10}".format(name="Bob")
'Bob '

如你所见,数和字符串的对齐方式不同。
精度也是使用整数指定的,但需要在它前面加上一个表示小数点的句点。

当然,可以同时指定宽度和精度。

>>> "{pi:10.2f}".format(pi=pi)
' 3.14'
# 实际上,对于其他类型也可指定精度,但是这样做的情形不太常见。
>>> "{:.5}".format("Guido van Rossum")
'Guido'

可使用逗号来指出你要添加千位分隔符。

>>> 'One googol is {:,}'.format(10**100)
'One googol is 10,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,00
0,000,000,000,000,000,000,000,000,000,000,000,000,000,000'

符号、对齐和用0 填充

字符串和数的默认对齐方式不同: 字符串默认左对齐,数默认右对齐
对数据进行指定宽度和精度后,默认是用空格填空。

但是我们可以自定义对齐方式和填充。

在指定宽度和精度的数前面,可添加一个标志。这个标志可以是零、加号、减号或空格,其中零表示使用0来填充数字。

>>> '{:010.2f}'.format(pi)
'0000003.14'

要指定左对齐、右对齐和居中,可分别使用<、>和^。

>>> print('{0:<10.2f}\n{0:^10.2f}\n{0:>10.2f}'.format(pi))
3.14
   3.14
      3.14

可以使用填充字符来扩充对齐说明符,这样将使用指定的字符而不是默认的空格来填充。

>>> "{:$^15}".format(" WIN BIG ")
'$$$ WIN BIG $$$'

还有更具体的说明符=,它指定将填充字符放在符号和数字之间。

>>> print('{0:10.2f}\n{1:10.2f}'.format(pi, -pi))
3.14
-3.14

>>> print('{0:10.2f}\n{1:=10.2f}'.format(pi, -pi))
3.14
- 3.14

如果要给正数加上符号,可使用说明符+(将其放在对齐说明符后面),而不是默认的-。
如果将符号说明符指定为空格,会在正数前面加上空格而不是+。

>>> print('{0:-.2}\n{1:-.2}'.format(pi, -pi)) #默认设置
3.1
-3.1
>>> print('{0:+.2}\n{1:+.2}'.format(pi, -pi))
+3.1
-3.1
>>> print('{0: .2}\n{1: .2}'.format(pi, -pi))
 3.1# 前面有个空格
-3.1

需要介绍的最后一个要素是井号(#)选项,这个选项将触发另一种转换方式,转换细节随类型而异。
将其放在符号说明符和宽度之间(如果指定了这两种设置)。

# 对于二进制、八进制和十六进制转换,将加上一个前缀。
>>> "{:b}".format(42)
'101010'
>>> "{:#b}".format(42)
'0b101010'
# 对于各种十进制数,它要求必须包含小数点(对于类型g,它保留小数点后面的零)。
>>> "{:g}".format(42)
'42'
>>> "{:#g}".format(42)
'42.0000'
posted @ 2022-06-07 10:40  kingwzun  阅读(161)  评论(0编辑  收藏  举报