让我们来谈谈python中的prettyprint和pprint

当你开始学习python编程的时候,你做的第一件事是什么?

让我们来谈谈python中的prettyprint和pprint

相信我们都已经通过“Hello World”程序开始了我们的python之旅。在python中,它可以在一行中完成:

print(“Hello World”) 

但是,在使用print()函数打印字典、列表或任何其他复杂数据类型时,您是否遇到过这种痛苦呢?由于不适当的缩进问题,我们经常在python嵌套数据结构的输出中遇到可读性方面的困难。

让我们在这里试试代码:

coordinates = [ 
 { 
 “name”: “Location 1”, 
 “gps”: (29.008966, 111.573724) 
 }, 
 { 
 “name”: “Location 2”, 
 “gps”: (40.1632626, 44.2935926) 
 }, 
 { 
 “name”: “Location 3”, 
 “gps”: (29.476705, 121.869339) 
 } 
] 
print(coordinates) 

以上代码的输出:

[{‘gps’: (29.008966, 111.573724), ‘name’:  
‘Location 1’}, {‘gps’: (40.1632626, 44.2935926),  
‘name’: ‘Location 2’}, {‘gps’: (29.476705, 121.869339),  
‘name’: ‘Location 3’}] 

我们可以看到,上面的代码不容易读懂,也不美观。

如果解决这个问题呢?

Python附带pprint模块,可以让打印任意数据结构更具可读性。

让我们来谈谈python中的prettyprint和pprint

pprint是什么?

python中的pprint模块负责以合适的格式打印便于阅读的行块。它使用换行和缩进以明确的方式打印数据。

pprint与print有何不同?

print()是python中的一个简单函数,用于在屏幕上向用户显示指定的消息。但通常,如果我们使用python打印一个字典、列表或任何其他复杂的函数,我们会发现读取打印出来的语句是模棱两可的。它包括内置的对象、文件、套接字、类或实例,这些不能用Python常量表示。

然后,“pprint”模块可以帮助您。

它将对象格式化为可读的格式,每行都有适当的宽度。它带有可调节的宽度限制,以使它更容易为用户。它将所有元素转换为可以用Python常量表示的字符串,并以美观的格式打印它们。pprint函数返回可以在解释器中作为输入运行的输出。而且,通过解析字符串更容易将其转换回该类型。

那么,让我们深入pprint…

在python文件的顶部导入库pprint:

import pprint 

现在,我们可以使用.pprint()对象或实例化我们自己的pprint对象PrettyPrinter()。

pprint.pprint(['Radha', 1, 'Hari', 'Simesh', 25, 847]) 
# Instantiating pprint object 
my_pprint = pprint.PrettyPrinter() 
my_pprint.pprint(['Radha', 1, 'Hari', 'Simesh', 25, 847]) 

两个打印函数给出的结果是一致的

['Radha', 1, 'Hari', 'Simesh', 25, 847]  
['Radha', 1, 'Hari', 'Simesh', 25, 847] 

那么,pprint()和PrettyPrinter()之间的区别是什么?

如果需要调整宽度约束或其他参数,则显式地构造PrettyPrinter对象。

语法:

class pprint.PrettyPrinter(indent=1, width=80, depth=None, 
 stream=None, *, compact=False, sort_dicts=True) 

pprint()方法使用库的默认设置,而在创建PrettyPrinter()对象时,我们可以更改库的默认配置。这就是二者之间的区别。​

让我们通过几个例子来理解:

深度参数决定多远一个Python PrettyPrinter递归嵌套结构:

tuple1 = ('spam', ('eggs', ('lumberjack', ('knights',  
('ni', ('dead',('parrot', ('fresh fruit',)))))))) 
# Using PrettyPrinter 
pp = pprint.PrettyPrinter(depth=6) # default configuration  
# of depthbeing none is changed to depth = 6 
# Now it will print till depth of six brackets 
pp.pprint(tuple1) 
#Using only pprint() object 
pprint.pprint(pprint.pprint(tuple1, depth=6)) 
pprint.pprint(tuple1) 

以上代码的输出:

('spam', ('eggs', ('lumberjack', ('knights', ('ni',  
('dead', (...)))))))  
('spam', ('eggs', ('lumberjack', ('knights', ('ni',  
('dead', (...))))))) 
('spam', 
  ('eggs', 
   ('lumberjack', ('knights', ('ni', ('dead',  
   ('parrot', ('fresh fruit',)))))))) 

你能注意到其中的区别吗?

我们看到,当tuple1打印使用深度= 6,之后六个椭圆打印的时候是没有更多的数据显示而只使用pprint.pprint(),那么所有的数据显示。

设置不存储在.pprint()中,即默认设置保持不变,而在PrettyPrinter()中,设置或更改是存储的。这里存储的是depth = 6。

使用宽度参数,我们可以选择输出将打印多少列。默认宽度是80,也就是80个字符,但是你可以改变它。

现在,让我们看看在几个内置函数中使用pprint()比print()函数的主要区别和好处。

from pprint import pprint # We can directly call the method  
# pprint() using it 
coordinates = [ 
 { 
 “name”: “Location 1”, 
 “gps”: (29.008966, 111.573724) 
 }, 
 { 
 “name”: “Location 2”, 
 “gps”: (40.1632626, 44.2935926) 
 }, 
 { 
 “name”: “Location 3”, 
 “gps”: (29.476705, 121.869339) 
 } 
] 
pprint(coordinates) 

输出:

[{'gps': (29.008966, 111.573724), 'name': 'Location 1'}, 
 {'gps': (40.1632626, 44.2935926), 'name': 'Location 2'}, 
 {'gps': (29.476705, 121.869339), 'name': 'Location 3'}] 

这就是本文中关于python中的pprint的全部内容。

相关推荐