[Python] Use pprint module to print arbitrary Python data structures pretty
pprint
The pprint
module provides a capability to “pretty-print” arbitrary Python data structures in a form which can be used as input to the interpreter. If the formatted structures include objects which are not fundamental Python types, the representation may not be loadable. This may be the case if objects such as files, sockets or classes are included, as well as many other objects which are not representable as Python literals.
The formatted representation keeps objects on a single line if it can, and breaks them onto multiple lines if they don’t fit within the allowed width. Construct PrettyPrinter objects explicitly if you need to adjust the width constraint.
Dictionaries are sorted by key before the display is computed.
Usages
PrettyPrinter
The pprint
module defines one class:
class pprint.PrettyPrinter(indent=1, width=80, depth=None, stream=None, *, compact=False, sort_dicts=True)
Construct a PrettyPrinter
instance. This constructor understands several keyword parameters.
-
An output stream may be set using the stream keyword; the only method used on the stream object is the file protocol’s
write()
method. If not specified, thePrettyPrinte
r adoptssys.stdout
. -
The amount of indentation added for each recursive level is specified by indent; the default is one. Other values can cause output to look a little odd, but can make nesting easier to spot. The number of levels which may be printed is controlled by depth; if the data structure being printed is too deep, the next contained level is replaced by … By default, there is no constraint on the depth of the objects being formatted.
-
The desired output width is constrained using the width parameter; the default is 80 characters. If a structure cannot be formatted within the constrained width, a best effort will be made.
-
If compact is false (the default) each item of a long sequence will be formatted on a separate line. If compact is true, as many items as will fit within the width will be formatted on each output line.
-
If sort_dicts is true (the default), dictionaries will be formatted with their keys sorted, otherwise they will display in insertion order.
1 | import pprint |
Shortcut Functions
The pprint module also provides several shortcut functions:
pprint.pformat(object, indent=1, width=80, depth=None, *, compact=False, sort_dicts=True)
Return the formatted representation of object as a string. indent, width, depth, compact and sort_dicts will be passed to the PrettyPrinter constructor as formatting parameters.
1 | ``` |
pprint.isreadable(object)
Determine if the formatted representation of object is “readable”, or can be used to reconstruct the value using eval(). This always returns False for recursive objects.
1 | pprint.isreadable(stuff) |
pprint.isrecursive(object)
Determine if object requires a recursive representation.
pprint.saferepr(object)
Return a string representation of object, protected against recursive data structures. If the representation of object exposes a recursive entry, the recursive reference will be represented as <Recursion on typename with id=number>
. The representation is not otherwise formatted.
1 | pprint.saferepr(stuff) |
Example
To demonstrate several uses of the pprint()
function and its parameters, let’s fetch information about a project from PyPI:
1 | import json |