假设我有这样的(嵌套)字典(注意列表值):
dic = {'level1':
{'level2':(1, 2),
'level3':
[
{'level4': (1, 2)},
{'level5': (1, 2)}
]
}
}
我正在寻找打印此词典的正确方法,我正在使用json
执行此操作:
import json
print json.dumps(dic, indent=4)
以上代码给出了以下输出:
{
"level1": {
"level2": [
1,
2
],
"level3": [
{
"level4": [
1,
2
]
},
{
"level5": [
1,
2
]
}
]
}
}
虽然上面的输出非常好,但仍然很难阅读,特别是如果有很多级别和更长的名称。
我也试过yaml
import yaml
print yaml.dump(dic)
给出以下看起来很奇怪的内容:
level1:
level2: !!python/tuple [1, 2]
level3:
- level4: !!python/tuple [1, 2]
- level5: !!python/tuple [1, 2]
是否有其他库可以产生更好的转储,我认为下面的输出更容易阅读:
"level1"
|---"level2": 1, 2
|---"level3":
|---"level4": 1, 2
|---"level5": 1, 2
我相信以上内容更容易阅读,并且可能有python库可以做到这一点。
答案 0 :(得分:1)
这是从一个activestate代码示例改编而来的。不能说它漂亮,但可能会让你朝着正确的方向前进:
myDict = {'level1':
{'level2':(1, 2),
'level3':
[
{'level4': (1, 2)},
{'level5': (1, 2)},
],
'level6': [1,2,3],
'level7':{'level8': (1,2), 'level9': (1,2)}
}
}
def prettyPrint(dictionary, ident = '', braces=1):
for key, value in dictionary.iteritems():
if isinstance(value, dict):
print '%s%s%s%s' % (ident, braces*'[', key, braces*']')
prettyPrint(value, ident+' ', braces+1)
elif isinstance(value, list):
ndict=0
for v in value:
if isinstance(v, dict):
ndict += 1
if ndict:
print '%s%s' % (ident, key)
for e in value:
if isinstance(e, dict):
prettyPrint(e, ident+' ', braces+1)
else:
print ident+'%s : %s' %(key, e)
else:
print ident+'%s : %s' %(key, value)
else:
print ident+'%s : %s' %(key, value)
prettyPrint(myDict)
[level1]
level2 : (1, 2)
level3
level4 : (1, 2)
level5 : (1, 2)
level6 : [1, 2, 3]
[[level7]]
level8 : (1, 2)
level9 : (1, 2)