Python - 输出格式化



Python 中的输出格式化

Python 中的输出格式化用于使代码更易读,输出更友好。无论您是显示简单的文本字符串、复杂的数据结构还是创建报表,Python 都提供了几种格式化输出的方法。

这些方法包括使用:

  • 字符串模运算符 (%)
  • format() 方法
  • f-字符串(格式化字符串字面量)
  • 模板字符串

此外,Python 的 "textwrap" 和 "pprint" 模块提供了高级功能,用于换行文本和漂亮打印数据结构。

使用字符串模运算符 (%)

我们可以使用字符串模运算符 % 来格式化输出。此运算符是字符串独有的,弥补了缺少来自 C 的 printf() 系列函数的不足。格式说明符,如 %d%c%f%s,用作字符串中的占位符,类似于 C 中的占位符。

下面是一个简单的例子:

print ("My name is %s and weight is %d kg!" % ('Zara', 21))

它将产生以下输出

My name is Zara and weight is 21 kg!

使用 format() 方法

我们可以使用 format() 方法格式化输出,该方法在 Python 3.0 中引入,并已向后移植到 Python 2.6 和 2.7。

format() 方法是内置字符串类的一部分,允许进行复杂的变量替换和值格式化。与字符串模运算符相比,它被认为是一种更优雅、更灵活的格式化字符串的方法。

语法

format() 方法的一般语法如下:

str.format(var1, var2,...)

返回值

该方法返回一个格式化后的字符串。

字符串本身包含占位符 {},变量的值将依次插入其中。

示例

name="Rajesh"
age=23
print ("my name is {} and my age is {} years".format(name, age))

它将产生以下输出

my name is Rajesh and my age is 23 years

您可以将变量作为关键字参数用于 format() 方法,并在字符串中使用变量名作为占位符。

print ("my name is {name} and my age is {age}
years".format(name="Rajesh", age=23))

使用 F-字符串

F-字符串或格式化字符串字面量是 Python 中一种简单、快速且易于阅读的格式化字符串的方法。您可以通过在字符串的开头引号前添加一个f来创建 f-字符串。

在字符串内,您可以包含变量的占位符,这些占位符用花括号{}括起来。这些变量的值将插入到字符串的这些位置。

示例

在这个例子中,变量 "name" 和 "age" 被插入到字符串中 "{name}" 和 "{age}" 所在的位置。F-字符串使在字符串中包含变量值变得很容易,无需使用 format() 方法或字符串连接 −

name = 'Rajesh'
age = 23

fstring = f'My name is {name} and I am {age} years old'
print (fstring)

它将产生以下输出

My name is Rajesh and I am 23 years old

Python中的格式转换规则

你也可以指定 C 风格的格式化符号。唯一的区别是使用:代替%。例如,用{:s}代替%s,用{:d}代替%d,如下所示−

name = "Rajesh"
age = 23
print("my name is {:s} and my age is {:d} years".format(name, age))

你将得到如下所示的输出−

my name is Rajesh and my age is 23 years

模板字符串

string模块中的Template类提供了一种动态格式化字符串的替代方法。Template类的优点之一是可以自定义格式化规则。

一个有效的模板字符串或占位符由两部分组成:$符号后跟一个有效的Python标识符。

你需要创建一个Template类的对象,并将模板字符串作为参数传递给构造函数。接下来,调用Template类的substitute()方法。它将作为参数提供的数值放在模板字符串的位置。

示例

from string import Template

temp_str = "My name is $name and I am $age years old"
tempobj = Template(temp_str)
ret = tempobj.substitute(name='Rajesh', age=23)
print (ret)

它将产生以下输出

My name is Rajesh and I am 23 years old

textwrap模块

Python 的 textwrap 模块中的 wrap 类包含用于通过调整输入段落中的换行符来格式化和换行纯文本的功能。它有助于使文本格式良好且美观。

textwrap 模块具有以下便捷函数−

textwrap.wrap(text, width=70)

textwrap.wrap() 函数换行 text(字符串)中的单个段落,因此每行的长度最多为 width 个字符。返回输出行的列表,不包含最终换行符。可选关键字参数对应于 TextWrapper 的实例属性。width 默认为 70。

textwrap.fill(text, width=70)

textwrap.fill() 函数换行 text 中的单个段落,并返回包含换行段落的单个字符串。

这两种方法都在内部创建一个 TextWrapper 类对象并在其上调用单个方法。由于实例不会被重用,因此创建你自己的 TextWrapper 对象会更高效。

示例

import textwrap

text = '''
Python is a high-level, general-purpose programming language. Its design philosophy emphasizes code readability with the use of significant indentation via the off-side rule.

Python is dynamically typed and garbage-collected. It supports multiple programming paradigms, including structured (particularly procedural), object-oriented and functional programming. It is often described as a "batteries included" language due to its comprehensive standard library.
'''

wrapper = textwrap.TextWrapper(width=40)
wrapped = wrapper.wrap(text = text)

# Print output
for element in wrapped:
   print(element)

它将产生以下输出

Python is a high-level, general-purpose
programming language. Its design
philosophy emphasizes code readability
with the use of significant indentation
via the off-side rule. Python is
dynamically typed and garbage-collected.
It supports multiple programming
paradigms, including structured
(particularly procedural), objectoriented and functional programming. It
is often described as a "batteries
included" language due to its
comprehensive standard library.

TextWrapper 对象定义了以下属性−

  • width − (默认值:70)换行行的最大长度。

  • expand_tabs − (默认值:True)如果为真,则文本中的所有制表符都将使用 text 的 expandtabs() 方法扩展为空格。

  • tabsize − (默认值:8)如果 expand_tabs 为真,则文本中的所有制表符都将扩展为零个或多个空格,具体取决于当前列和给定的制表符大小。

  • replace_whitespace − (默认值:True)如果为真,则在制表符扩展之后但在换行之前,wrap() 方法将用单个空格替换每个空格字符。

  • drop_whitespace − (默认值:True)如果为真,则会删除每行开头和结尾的空格(换行后但在缩进之前)。但是,如果后面跟着非空格,则不会删除段落开头的空格。如果被删除的空格占据整行,则整行都会被删除。

  • initial_indent − (默认值:'')将预先添加到换行输出第一行的字符串。

  • subsequent_indent − (默认值:'')将预先添加到换行输出所有行(第一行除外)的字符串。

  • fix_sentence_endings − (默认值:False)如果为真,则 TextWrapper 尝试检测句子结尾并确保句子始终用两个空格隔开。这通常对于等宽字体中的文本是需要的。

  • break_long_words − (默认值:True)如果为真,则长于 width 的单词将被拆分,以确保没有行的长度超过 width。如果为假,则长单词不会被拆分,并且某些行的长度可能超过 width。

  • break_on_hyphens − (默认值:True)如果为真,则换行最好在空格处和复合词中的连字符之后进行,这在英语中很常见。如果为假,则只有空格会被视为潜在的良好换行位置。

shorten() 函数

shorten() 函数折叠并截断给定的文本以适应给定的宽度。文本首先压缩其空格。如果随后适合 *width*,则按原样返回。否则,将尽可能多的单词连接起来,然后附加占位符 −

示例

import textwrap

python_desc = """Python is a general-purpose interpreted, interactive, object-oriented, and high-level programming language. It was created by Guido van Rossum during 1985- 1990. Like Perl, Python source code is also available under the GNU General Public License (GPL). This tutorial gives enough understanding on Python programming language."""

my_wrap = textwrap.TextWrapper(width = 40)

short_text = textwrap.shorten(text = python_desc, width=150)
print('\n\n' + my_wrap.fill(text = short_text))

它将产生以下输出

Python is a general-purpose interpreted,
interactive, object-oriented,and high
level programming language. It was 
created by Guido van Rossum [...]

pprint 模块

Python 标准库中的pprint模块使 Python 数据结构的外观更美观。pprint 代表 pretty printer(漂亮打印机)。任何可以被 Python 解释器正确解析的数据结构都会被优雅地格式化。

格式化的表达式尽可能保持在一行中,但如果长度超过格式化的宽度参数,则会换成多行。pprint 输出的一个独特之处在于,字典在显示表示形式格式化之前会自动排序。

PrettyPrinter 类

pprint 模块包含PrettyPrinter类的定义。其构造函数采用以下格式−

语法

pprint.PrettyPrinter(indent, width, depth, stream, compact)

参数

  • indent − 定义每个递归级别添加的缩进。默认为 1。

  • width − 默认值为 80。所需的输出受此值限制。如果长度大于 width,则将其分成多行。

  • depth − 控制要打印的级别数。

  • stream − 默认情况下为 std.out − 默认输出设备。它可以采用任何流对象,例如文件。

  • compact − 默认情况下设置为 False。如果为真,则只显示可在 width 内调整的数据。

PrettyPrinter 类定义了以下方法−

pprint() 方法

pprint() 方法打印 PrettyPrinter 对象的格式化表示形式。

pformat() 方法

pformat() 方法根据构造函数的参数返回对象的格式化表示形式。

示例

以下示例演示了 PrettyPrinter 类的简单用法−

import pprint
students={"Dilip":["English", "Maths", "Science"],"Raju":{"English":50,"Maths":60, "Science":70},"Kalpana":(50,60,70)}
pp=pprint.PrettyPrinter()
print ("normal print output")
print (students)
print ("----")
print ("pprint output")
pp.pprint(students)

输出显示了普通打印和漂亮打印−

normal print output
{'Dilip': ['English', 'Maths', 'Science'], 'Raju': {'English': 50, 'Maths': 60, 'Science': 70}, 'Kalpana': (50, 60, 70)}
----
pprint output
{'Dilip': ['English', 'Maths', 'Science'],
 'Kalpana': (50, 60, 70),
 'Raju': {'English': 50, 'Maths': 60, 'Science': 70}}

pprint模块还定义了与 PrettyPrinter 方法对应的便捷函数 pprint() 和 pformat()。下面的示例使用 pprint() 函数。

from pprint import pprint
students={"Dilip":["English", "Maths", "Science"],
   "Raju":{"English":50,"Maths":60, "Science":70},
      "Kalpana":(50,60,70)}
print ("normal print output")
print (students)
print ("----")
print ("pprint output")
pprint (students)

使用 pformat() 方法的示例

下一个示例使用 pformat() 方法和 pformat() 函数。要使用 pformat() 方法,首先要设置 PrettyPrinter 对象。在这两种情况下,格式化的表示形式都使用普通的 print() 函数显示。

import pprint
students={"Dilip":["English", "Maths", "Science"],
   "Raju":{"English":50,"Maths":60, "Science":70},
      "Kalpana":(50,60,70)}
print ("using pformat method")
pp=pprint.PrettyPrinter()
string=pp.pformat(students)
print (string)
print ('------')
print ("using pformat function")
string=pprint.pformat(students)
print (string)

以下是上述代码的输出−

using pformat method
{'Dilip': ['English', 'Maths', 'Science'],
 'Kalpana': (50, 60, 70),
 'Raju': {'English': 50, 'Maths': 60, 'Science': 70}}
------
using pformat function
{'Dilip': ['English', 'Maths', 'Science'],
 'Kalpana': (50, 60, 70),
 'Raju': {'English': 50, 'Maths': 60, 'Science': 70}}

漂亮打印也可以与自定义类一起使用。在类中重写 __repr__() 方法。当使用 repr() 函数时会调用 __repr__() 方法。它是 Python 对象的官方字符串表示形式。当我们使用对象作为 print() 函数的参数时,它会打印 repr() 函数的返回值。

示例

在这个例子中,__repr__() 方法返回 player 对象的字符串表示形式−

import pprint
class player:
   def __init__(self, name, formats=[], runs=[]):
      self.name=name
      self.formats=formats
      self.runs=runs
   def __repr__(self):
      dct={}
      dct[self.name]=dict(zip(self.formats,self.runs))
      return (repr(dct))

l1=['Tests','ODI','T20']
l2=[[140, 45, 39],[15,122,36,67, 100, 49],[78,44, 12, 0, 23, 75]]
p1=player("virat",l1,l2)
pp=pprint.PrettyPrinter()
pp.pprint(p1)

以上代码的输出为−

{'virat': {'Tests': [140, 45, 39], 'ODI': [15, 122, 36, 67, 100, 49],
'T20': [78, 44, 12, 0, 23, 75]}}
广告