Python构造自定义方法来美化字典结构输出的示例

示例:


d = { "root": { "folder2": { "item2": None,"item1": None },"folder1": { "subfolder1": { "item2": 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,v) 
 print ''.join(_pretty(obj,indent)) 
 
d = { "root": { "folder2": { "item2": None,"subfolder2": { "item3": None } } } } 
pretty_dict(d) 

相关文章

使用爬虫利器 Playwright,轻松爬取抖查查数据 我们先分析登...
轻松爬取灰豚数据的抖音商品数据 调用两次登录接口实现模拟登...
成功绕过阿里无痕验证码,一键爬取飞瓜数据 飞瓜数据的登录接...
一文教你从零开始入门蝉妈妈数据爬取,成功逆向破解数据加密...
抽丝剥茧成功破解红人点集的签名加密算法 抽丝剥茧破解登录签...
轻松绕过 Graphql 接口爬取有米有数的商品数据 有米有数数据...