有没有Python库可以将字典输出为漂亮的ASCII表格?

9

我这里有一个非常庞大的字典,但其中大部分内容都是反复出现的。我正在寻找一些代码,可以将该字典以ASCII表格的形式显示出来,并输出到命令行。至少应该生成一些用于非维度字典的列,其余部分可以作为单元格中的键值对,例如:

dictionary = {"column1":{"key":"val"}, "column2": "value" }

=====================
| column1 | column2 |
=====================
| key:val | value   |

相比快速获取信息时看到所有这些u"" {} ,,还是更好的。


你看过pprint吗?它肯定不是你描述的格式,但可能比你得到的更好。 - mgilson
是的,我已经使用它了,它非常丑陋,就像普通字典的转储一样,与json_dumps()做的一样。这里没有什么特别的。我该如何创建正常的TUI..类似ncurses但更轻便,只需将字典输出到表格中.. mysql cli客户端实际上也是这样做的.. - holms
这段代码大概是实现了类似这样的功能,可能会自己实现一个高效的字典支持... http://code.activestate.com/recipes/577202-render-tables-for-text-interface/ - holms
1个回答

15

你可以使用prettytable来呈现漂亮的表格。

t = PrettyTable(['key', 'value'])
for key, val in dictionary.items():
   t.add_row([key, val])
print t

您还可以使用textwrap模块来将值分成多行(此代码片段中有例子)。想象一下,您想显示os.environ的内容;结果如下(简短版):
+------------------------------+--------------------------------------------------------------+
|             key              |                            value                             |
+------------------------------+--------------------------------------------------------------+
|            CFLAGS            |           -fno-strict-aliasing -O2 -g -pipe -Wall            |
|                              |    -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector    |
|                              | --param=ssp-buffer-size=4  -m64 -mtune=generic -D_GNU_SOURCE |
|                              |         -fPIC -fwrapv   -DNDEBUG -O2 -g -pipe -Wall          |
|                              |    -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector    |
|                              | --param=ssp-buffer-size=4  -m64 -mtune=generic -D_GNU_SOURCE |
|                              |                        -fPIC -fwrapv                         |
|             MAIL             |                    /var/spool/mail/damien                    |
|          LS_COLORS           | rs=0:di=01;34:ln=01;36:mh=00:pi=40;33:so=01;35:do=01;35:bd=4 |
|                              | 0;33;01:cd=40;33;01:or=40;31;01:mi=01;05;37;41:su=37;41:sg=3 |
|                              | 0;43:ca=30;41:tw=30;42:ow=34;42:st=37;44:ex=01;32:*.tar=01;3 |
|                              | 1:*.tgz=01;31:*.arj=01;31:*.taz=01;31:*.lzh=01;31:*.lzma=01; |
|                              | 31:*.tlz=01;31:*.txz=01;31:*.zip=01;31:*.z=01;31:*.Z=01;31:* |
|                              | .dz=01;31:*.gz=01;31:*.lz=01;31:*.xz=01;31:*.bz2=01;31:*.tbz |
|                              | =01;31:*.tbz2=01;31:*.bz=01;31:*.tz=01;31:*.deb=01;31:*.rpm= |
|                              | 01;31:*.jar=01;31:*.war=01;31:*.ear=01;31:*.sar=01;31:*.rar= |
|                              | 01;31:*.ace=01;31:*.zoo=01;31:*.cpio=01;31:*.7z=01;31:*.rz=0 |
|                              | 1;31:*.jpg=01;35:*.jpeg=01;35:*.gif=01;35:*.bmp=01;35:*.pbm= |
|                              | 01;35:*.pgm=01;35:*.ppm=01;35:*.tga=01;35:*.xbm=01;35:*.xpm= |
|                              | 01;35:*.tif=01;35:*.tiff=01;35:*.png=01;35:*.svg=01;35:*.svg |
|                              | z=01;35:*.mng=01;35:*.pcx=01;35:*.mov=01;35:*.mpg=01;35:*.mp |
|                              | eg=01;35:*.m2v=01;35:*.mkv=01;35:*.ogm=01;35:*.mp4=01;35:*.m |
|                              | 4v=01;35:*.mp4v=01;35:*.vob=01;35:*.qt=01;35:*.nuv=01;35:*.w |
|                              | mv=01;35:*.asf=01;35:*.rm=01;35:*.rmvb=01;35:*.flc=01;35:*.a |
|                              | vi=01;35:*.fli=01;35:*.flv=01;35:*.gl=01;35:*.dl=01;35:*.xcf |
|                              | =01;35:*.xwd=01;35:*.yuv=01;35:*.cgm=01;35:*.emf=01;35:*.axv |
|                              | =01;35:*.anx=01;35:*.ogv=01;35:*.ogx=01;35:*.aac=01;36:*.au= |
|                              | 01;36:*.flac=01;36:*.mid=01;36:*.midi=01;36:*.mka=01;36:*.mp |
|                              | 3=01;36:*.mpc=01;36:*.ogg=01;36:*.ra=01;36:*.wav=01;36:*.axa |
|                              | =01;36:*.oga=01;36:*.spx=01;36:*.xspf=01;36:*.pdf=00;33:*.ps |
|                              | =00;33:*.ps.gz=00;33:*.txt=00;33:*.patch=00;33:*.diff=00;33: |
|                              | *.log=00;33:*.tex=00;33:*.xls=00;33:*.xlsx=00;33:*.ppt=00;33 |
|                              | :*.pptx=00;33:*.rtf=00;33:*.doc=00;33:*.docx=00;33:*.odt=00; |
|                              | 33:*.ods=00;33:*.odp=00;33:*.xml=00;33:*.epub=00;33:*.abw=00 |
|                              |   ;33:*.htm=00;33:*.html=00;33:*.shtml=00;33:*.wpd=00;33:    |
|       GJS_DEBUG_TOPICS       |                       JS ERROR;JS LOG                        |
+------------------------------+--------------------------------------------------------------+

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接