假设我有一个(嵌套的)字典,如下所示(注意lists value):
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库可以做到这一点。
发布于 2013-03-08 04:44:21
这是从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)https://stackoverflow.com/questions/15275766
复制相似问题