示例:

复制代码 代码如下:
d = { \”root\”: { \”folder2\”: { \”item2\”: None, \”item1\”: None }, \”folder1\”: { \”subfolder1\”: { \”item2\”: None, \”item1\”: None }, \”subfolder2\”: { \”item3\”: None } } } }

美观输出是:

2016616162825558.jpg (440×72)

观察一下特点:
1.同一level的key左对齐,即indent相同。
2.在,号后换行。
3.如果value是字典,即嵌套字典,则嵌套字典在下一个level,每一个level的key的indent都不一样。

思路分析:
这是个\”拼接字符串\”问题,元素有\”\”{}:,\\n和空格indent。
遍历一个个(k, v)键值对,拼接yield起来,遇到嵌套字典就递归,即递归+yield。

上代码。

#coding=utf-8 
def pretty_dict(obj, indent=\' \'): 
 def _pretty(obj, indent): 
  for i, tup in enumerate(obj.items()): 
   k, v = tup 
   #如果是字符串则拼上\"\" 
   if isinstance(k, basestring): k = \'\"%s\"\'% k 
   if isinstance(v, basestring): v = \'\"%s\"\'% v 
   #如果是字典则递归 
   if isinstance(v, dict): 
    v = \'\'.join(_pretty(v, indent + \' \'* len(str(k) + \': {\')))#计算下一层的indent 
   #case,根据(k,v)对在哪个位置确定拼接什么 
   if i == 0:#开头,拼左花括号 
    if len(obj) == 1: 
     yield \'{%s: %s}\'% (k, v) 
    else: 
     yield \'{%s: %s,\\n\'% (k, v) 
   elif i == len(obj) - 1:#结尾,拼右花括号 
    yield \'%s%s: %s}\'% (indent, k, v) 
   else:#中间 
    yield \'%s%s: %s,\\n\'% (indent, k, v) 
 print \'\'.join(_pretty(obj, indent)) 
 
d = { \"root\": { \"folder2\": { \"item2\": None, \"item1\": None }, \"folder1\": { \"subfolder1\": { \"item2\": None, \"item1\": None }, \"subfolder2\": { \"item3\": None } } } } 
pretty_dict(d)