如何以表格形式和字母顺序打印字典?

时间:2015-04-15 15:14:13

标签: python dictionary python-3.4 tabular

我有一本字典,希望以表格形式打印,第一个标题为“代码”,第二个标题为“名称”,然后按字母顺序排序。

我目前:

 import json
 q = my_dict() #which is the dictionary
 d = json.dumps(q)
 print(d)

输出:

"GEL": "Georgian Lari",
"BOB": "Bolivian Boliviano",
"ZAR": "South African Rand",

这是错误的方式,我不知道如何插入列标题。按字母顺序排序也会对我有所帮助!

Name                   Code
"Bolivian Boliviano"   "BOB"
"Georgian Lari"        "GEL"
"South African Rand"   "Zar"

像我这样的东西正在寻找。

3 个答案:

答案 0 :(得分:8)

如果可以选择第三方模块,则可以使用tabulate

从命令行运行:

$ pip install tabulate

然后在你的脚本中

from tabulate import tabulate

headers = ['Name', 'Code']
data = sorted([(v,k) for k,v in d.items()]) # flip the code and name and sort
print(tabulate(data, headers=headers))

那会给你输出

Name                Code
------------------  ------
Bolivian Boliviano  BOB
Georgian Lari       GEL
South African Rand  ZAR

答案 1 :(得分:6)

我不确定您是否需要引号,但您可以按照自己的顺序打印字典:

max_len = max([len(v) for v in d.values()])
padding = 4
for k,v in sorted(d.items(), key=lambda i:i[1]):
    print('{v:{v_len:d}s} {k:3s}'.format(v_len=max_len+padding,
                                           v=v, k=k))

输出:

Bolivian Boliviano     BOB
Georgian Lari          GEL
South African Rand     ZAR

key的{​​{1}}参数确保字典的项目按值排序。

编辑:根据要求,使字段长度与字典值长度匹配(加上一些填充)。

答案 2 :(得分:1)

这是我要怎么做:

import pandas as pd

pd.DataFrame(d)