zoukankan      html  css  js  c++  java
  • 打印 Python 的一切 —— pprint & beeprint

    打印,是所有程序员从小白时期就具备的神技,遇事不决打印一下,是 DEBUG 最简单且不依赖 IDE 的方式,自定义各种日志输出,也是项目成型后必备功能。
    但是为了优雅的打印格式,往往需要对各种对象进行特殊格式化,可遇到字典和大段字符串也不好处理。
    这篇文章介绍两个库模块,可以快速有效的解决所有 Python 对象的打印输出,没错,所有。

    pprint

    这是 Python 标准库模块,全称 pretty printer,可以让各种数据结构更美观地输出。

    >>> print(game)
    {'players': [{'name': 'player_1', 'hp': 3}, {'name': 'player_2', 'hp': 5}]}
    >>> pprint.pprint(game, width=4)
    {'players': [{'hp': 3,
                  'name': 'player_1'},
                 {'hp': 5,
                  'name': 'player_2'}]}
    

    pprint.pprint(objectstream=Noneindent=1width=80depth=None*compact=False)

    • stream:输出流,默认是 sys.stdout ,也就是屏幕输出。
    • indent:缩进空格数。
    • width:每行最大宽度,默认为80个字符,超过宽度会换行,但如果单个对象超过不会被换行,比如一段长字符串。
    • depth:限制数据的层级,设置后可以限制过多的嵌套。
    • compact:3.4版本新加入的参数,若设为 True ,则输出会在接近 width 限制才进行换行。
    >>> pprint.pprint(stuff, indent=4)
    [   ['spam', 'eggs', 'lumberjack', 'knights', 'ni'],
        'spam',
        'eggs',
        'lumberjack',
        'knights',
        'ni']
    >>> pprint.pprint(stuff, width=41, compact=True)
    [['spam', 'eggs', 'lumberjack',
      'knights', 'ni'],
     'spam', 'eggs', 'lumberjack', 'knights',
     'ni']
    

    pprint.pformat(objectindent=1width=80depth=None*compact=False)

    和 pprint.pprint 的区别是,该函数不会打印到输出流,而是返回一个格式化字符串。

    >>> stuff = ['spam', 'eggs', 'lumberjack', 'knights', 'ni']
    >>> stuff.insert(0, stuff)
    >>> pprint.pprint(stuff)
    [<Recursion on list with id=...>,
     'spam',
     'eggs',
     'lumberjack',
     'knights',
     'ni']
    

    classpprint.PrettyPrinter(indent=1width=80depth=Nonestream=None*compact=False)

    上文两个函数,实际都是构建一个 PrettyPrinter 对象,并调用对应的方法,所以当需要复用格式化的时候,我们可以提前构建该对象。

    >>> pp = pprint.PrettyPrinter(width=40, compact=True)
    >>> pp.pprint(game)
    {'players': [{'hp': 3,
                  'name': 'player_1'},
                 {'hp': 5,
                  'name': 'player_2'}]}
    >>> pp.pprint(stuff)
    ['spam', 'eggs', 'lumberjack',
     'knights', 'ni']
    

    更多用法可以参考官方文档:

    8.11. pprint - Data pretty printer - Python 3.5.6 documentation​docs.python.org


    pprint 对字典 列表这类数据结构确实很好用,但遇到类、字符串仍然和 print 差别不大,因此这里有一个国人写的第三方库介绍给大家。

    beeprint

    除了和 pprint 一样支持 dict, list, tuple 等常规变量的格式化输出,还支持 object 变量打印、长文本自动剪切。

    下面是作者 README 中和 pprint 的对比:

    pprint:

    {'entities': {'hashtags': [],
                  'urls': [{'display_url': 'tumblr.com/xnr37hf0yz',
                            'expanded_url': 'http://tumblr.com/xnr37hf0yz',
                            'indices': [107, 126],
                            'url': 'http://t.co/cCIWIwg'}],
                  'user_mentions': []}}
    

    beeprint:

    {
      'entities': {
        'hashtags': [],
        'urls': [
          {
            'display_url': 'tumblr.com/xnr37hf0yz',
            'expanded_url': 'http://tumblr.com/xnr37hf0yz',
            'indices': [107, 126],
            'url': 'http://t.co/cCIWIwg',
          },
        ],
        'user_mentions': [],
      },
    }
    

    pprint:

    <class 'definition.NormalClassNewStyle'>
    

    beeprint:

    class(NormalClassNewStyle):
      dicts: {
      },
      lists: [],
      static_props: 1,
      tuple: (1, 2)
    

    pprint:

    <definition.NormalClassNewStyle object at 0x7f338e5a9dd0>
    

    beeprint:

    instance(NormalClassNewStyle):
      dicts: {
      },
      lists: [],
      say_hi: 'hello world',
      static_props: 1,
      tuple: (1, 2)
    

    pprint:

    [['
    The sky and the earth were at first one blurred entity like an egg. Pangu was born into it.
     
    	The separation of the sky and the earth took eighteen thousand years-the yang which was light and pure rose to become the sky, 	and the yin which was heavy and murkyxefxbcx88xe6x9cxa6xe8x83xa7xe7x9ax84xefxbcx89 sank to form the earth. Between them was Pangu, who went through nine 	changes every day, his wisdom greater than that of the sky and his ability greater than that of the earth. Every day the sky rose ten feet higher, the earth became ten feet thicker, and Pangu grew ten feet taller.
     
    Another eighteen thousand years passed, and there was an extremely high sky, an extremely thick earth, and an extremely tall Pangu. After Pangu died, his head turned into the Five Sacred Mountains (Mount Tai, Mount Heng, Mount Hua, Mount Heng, Mount Song), his eyes turned into the moon and the sun, his blood changed into water in river and sea, his hair into grass.
     
    In all, the universe and Pangu combine in one.
    ',
      '
    xe6x8dxaexe6xb0x91xe9x97xb4xe7xa5x9exe8xafx9dxe4xbcxa0xe8xafxb4xe5x8fxa4xe6x97xb6xe7x9bx98xe5x8fxa4xe7x94x9fxe5x9cxa8xe9xbbx91xe6x9ax97xe5x9bxa2xe4xb8xadxefxbcx8cxe4xbbx96xe4xb8x8dxe8x83xbdxe5xbfx8dxe5x8fx97xe9xbbx91xe6x9ax97xefxbcx8cxe7x94xa8xe7xa5x9exe6x96xa7xe5x8ax88xe5x90x91xe5x9bx9bxe6x96xb9xefxbcx8cxe9x80x90xe6xb8x90xe4xbdxbfxe5xa4xa9xe7xa9xbaxe9xabx98xe8xbfx9cxefxbcx8cxe5xa4xa7xe5x9cxb0xe8xbexbdxe9x98x94xe3x80x82
    	xe4xbbx96xe4xb8xbaxe4xb8x8dxe4xbdxbfxe5xa4xa9xe5x9cxb0xe4xbcx9axe9x87x8dxe6x96xb0xe5x90x88xe5xb9xb6xefxbcx8cxe7xbbxa7xe7xbbxadxe6x96xbdxe5xb1x95xe6xb3x95xe6x9cxafxe3x80x82xe6xafx8fxe5xbdx93xe7x9bx98xe5x8fxa4xe7x9ax84xe8xbaxabxe4xbdx93xe9x95xbfxe9xabx98xe4xb8x80xe5xb0xbaxefxbcx8cxe5xa4xa9xe7xa9xbaxe5xb0xb1xe9x9ax8fxe4xb9x8bxe5xa2x9exe9xabx98xe4xb8x80xe5xb0xbaxefxbcx8c
    	xe7xbbx8fxe8xbfx871.8xe4xb8x87xe5xa4x9axe5xb9xb4xe7x9ax84xe5x8axaaxe5x8ax9bxefxbcx8cxe7x9bx98xe5x8fxa4xe5x8fx98xe6x88x90xe4xb8x80xe4xbdx8dxe9xa1xb6xe5xa4xa9xe7xabx8bxe5x9cxb0xe7x9ax84xe5xb7xa8xe4xbaxbaxefxbcx8cxe8x80x8cxe5xa4xa9xe7xa9xbaxe4xb9x9fxe5x8dx87xe5xbex97xe9xabx98xe4xb8x8dxe5x8fxafxe5x8fx8axefxbcx8cxe5xa4xa7xe5x9cxb0xe4xb9x9fxe5x8fx98xe5xbex97xe5x8ex9axe5xaex9exe6x97xa0xe6xafx94xe3x80x82xe7x9bx98xe5x8fxa4xe7x94x9fxe5x89x8dxe5xaex8cxe6x88x90xe5xbcx80xe5xa4xa9xe8xbex9fxe5x9cxb0xe7x9ax84xe4xbcx9fxe5xa4xa7xe4xb8x9axe7xbbxa9xefxbcx8cxe6xadxbbxe5x90x8exe6xb0xb8xe8xbfx9cxe7x95x99xe7xbbx99xe5x90x8exe4xbaxbaxe6x97xa0xe7xa9xb7xe6x97xa0xe5xb0xbdxe7x9ax84xe5xaex9dxe8x97x8fxefxbcx8cxe6x88x90xe4xb8xbaxe4xb8xadxe5x8dx8exe6xb0x91xe6x97x8fxe5xb4x87xe6x8bx9cxe7x9ax84xe8x8bxb1xe9x9bx84xe3x80x82
    ']]
    

    beeprint:

    [
      [
        '
    The sky and the earth were at first one blurred entity like an egg. Pangu
         was born into it.
     
    	The separation of the sky and the earth took
         ...(12 hidden lines)',
        '
    据民间神话传说古时盘古生在黑暗团中,他不能忍受黑暗,用神斧劈向四方,逐渐
         使天空高远,大地辽阔。
    	他为不使天地会重新合并,继续施展法术。每当盘古的
         ...(3 hidden lines)',
      ],
    ]
    

    beeprint.pp(o, output=True, max_depth=5, indent=2, width=80, sort_keys=True, config=None, **kwargs):

    参数和 pprint 类似,多出了 sort_keys可以打印字典时是否按 key 排序( pprint 是默认排序,不可选),另外还有控制文本裁剪等行为的参数,可以从 beeprint.Config 里查看。

    该库的 Github:https://github.com/panyanyany/beeprint

    欢迎关注

    微信公众号:面向人生编程

    编程思维不应只存留在代码之中,更应伴随于整个人生旅途,这个公众号不只聊技术,还会聊产品/互联网/经济学等广泛话题,所以也欢迎非程序员关注。

  • 相关阅读:
    docker 安装 mysql5.7
    docker 安装 redis
    docker 安装 gitlab
    docker 升级到新版本
    logstash 采集springboot 错误日志配置
    图片左下角添加水印
    frida动态修改
    反反frida调试
    IDA插件KeyPatch直接在IDA中修改arm指令
    frida调用制作dex(用于有些对象读取不了)
  • 原文地址:https://www.cnblogs.com/zkqiang/p/10515157.html
Copyright © 2011-2022 走看看