> 文章列表 > 【Python】如何使用 Python 的 pprint库格式化和输出列表和字典

【Python】如何使用 Python 的 pprint库格式化和输出列表和字典

【Python】如何使用 Python 的 pprint库格式化和输出列表和字典

这两天, 田辛老师在进行几个OpenCV的项目, 涉及到大量的dict以及list内容的输出。 不多不说, python的print函数对于字典和列表的表示并不友好。 在此时,我们可以通过使用 Python 的标准库 pprint 模块,以干净的格式输出和显示列表和字典等对象。pprint 是“pretty-print”的缩写。

1 pprint的基本用法

普通print()函数将列表和字典的元素打印在一行上,没有换行符。例如,如下代码

point_lst = [{'Name': '田辛', 'Age': 40, 'Points': [80, 20]}, {'Name': '张三', 'Age': 20, 'Points': [90, 10]},  {'Name': '李四', 'Age': 30, 'Points': [70, 30]}]
print(point_lst)
[{'Name': '田辛', 'Age': 40, 'Points': [80, 20]}, {'Name': '张三', 'Age': 20, 'Points': [90, 10]}, {'Name': '李四', 'Age': 30, 'Points': [70, 30]}]进程已结束,退出代码0

这个输出其实是相当不友好的。 这个list但凡长一点看起来就非常的麻烦, 那么这种情况下使用pprint的方法就很方便:

pprint.pprint(point_lst)

输出的结果是:

[{'Age': 40, 'Name': '田辛', 'Points': [80, 20]},{'Age': 20, 'Name': '张三', 'Points': [90, 10]},{'Age': 30, 'Name': '李四', 'Points': [70, 30]}]进程已结束,退出代码0

2 指定输出宽度(字符数):width

2.1 例子:

pprint.pprint(point_lst, width=40)

输出结果是:

[{'Age': 40,'Name': '田辛','Points': [80, 20]},{'Age': 20,'Name': '张三','Points': [90, 10]},{'Age': 30,'Name': '李四','Points': [70, 30]}]进程已结束,退出代码0

2.2 特殊说明

如果你给的width值特别大, 比如400, 那么这个时候pprint会和print没有区别。

pprint.pprint(point_lst, width=400)

输出结果是:

[{'Age': 40, 'Name': '田辛', 'Points': [80, 20]}, {'Age': 20, 'Name': '张三', 'Points': [90, 10]}, {'Age': 30, 'Name': '李四', 'Points': [70, 30]}]进程已结束,退出代码0

2.3 默认换行

默认情况下width会自动检查列表或者字典的元素是否适合输出, 如果不适合的话,他们将被换行。

pprint.pprint(list(range(10)))  
pprint.pprint(list(range(1000000, 1000010)))

输出结果是:

[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
[1000000,1000001,1000002,1000003,1000004,1000005,1000006,1000007,1000008,1000009]进程已结束,退出代码0

2.4 紧凑换行:compact=True

在默认换行中, 如果产生换行,列表的每个元素都会换行。 有的时候, 这种换行显示会过长。 在这种情况下, 可以使用紧凑换行。

pprint.pprint(list(range(1000000, 1000020)), compact=True)

输出结果是:

[1000000, 1000001, 1000002, 1000003, 1000004, 1000005, 1000006, 1000007,1000008, 1000009, 1000010, 1000011, 1000012, 1000013, 1000014, 1000015,1000016, 1000017, 1000018, 1000019]进程已结束,退出代码0

3 指定要打印的元素的深度:depth

您可以指定要输出的元素的深度depth作为参数。这里的深度就是嵌套数据的深度。

pprint.pprint(point_lst, depth=1)  
pprint.pprint(point_lst, depth=2)

输出结果是:

[{...}, {...}, {...}]
[{'Age': 40, 'Name': '田辛', 'Points': [...]},{'Age': 20, 'Name': '张三', 'Points': [...]},{'Age': 30, 'Name': '李四', 'Points': [...]}]进程已结束,退出代码0

查看上面的执行结果, 你会发现, 对于超出depth深度的部分, 会直接用...表示。

4 制定缩进的宽度:indent

通过设定indent可以指定缩进, 默认缩进为1, 读者可以仔细看刚的例子中, 第二行会有一个字符的缩进哦。

pprint.pprint(point_lst, width=4, indent=4)

输出结果是:

[   {   'Age': 40,'Name': '田辛','Points': [   80,20]},{   'Age': 20,'Name': '张三','Points': [   90,10]},{   'Age': 30,'Name': '李四','Points': [   70,30]}]进程已结束,退出代码0

5 全部代码

老规矩, 全部代码奉上:

#!/usr/bin/env python  
# -*- coding:utf-8 -*-  
"""  
#-----------------------------------------------------------------------------  
#                     --- TDOUYA STUDIOS ---  
#-----------------------------------------------------------------------------  
#  
# @Project : di08-tdd-cdg-python-learning  
# @File    : pprint_learning.py  
# @Author  : tianxin.xp@gmail.com  
# @Date    : 2023/4/15 17:16  
#  
# pprint 示例程序  
#  
#--------------------------------------------------------------------------"""  
import pprint  point_lst = [{'Name': '田辛', 'Age': 40, 'Points': [80, 20]}, {'Name': '张三', 'Age': 20, 'Points': [90, 10]},  {'Name': '李四', 'Age': 30, 'Points': [70, 30]}]  print(point_lst)  pprint.pprint(point_lst)  pprint.pprint(point_lst, width=40)  pprint.pprint(point_lst, width=400)  pprint.pprint(list(range(10)))  
pprint.pprint(list(range(1000000, 1000010)))  
pprint.pprint(list(range(1000000, 1000020)), compact=True)  pprint.pprint(point_lst, depth=1)  
pprint.pprint(point_lst, depth=2)  pprint.pprint(point_lst, width=4, indent=4)