示例:
美觀輸出是:

觀察一下特點(diǎn):
1.同一level的key左對(duì)齊,即indent相同。
2.在,號(hào)后換行。
3.如果value是字典,即嵌套字典,則嵌套字典在下一個(gè)level,每一個(gè)level的key的indent都不一樣。
思路分析:
這是個(gè)"拼接字符串"問(wèn)題,元素有""{}:,/n和空格indent。
遍歷一個(gè)個(gè)(k, v)鍵值對(duì),拼接yield起來(lái),遇到嵌套字典就遞歸,即遞歸+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) + ': {')))#計(jì)算下一層的indent #case,根據(jù)(k,v)對(duì)在哪個(gè)位置確定拼接什么 if i == 0:#開(kāi)頭,拼左花括號(hào) if len(obj) == 1: yield '{%s: %s}'% (k, v) else: yield '{%s: %s,/n'% (k, v) elif i == len(obj) - 1:#結(jié)尾,拼右花括號(hào) 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) 新聞熱點(diǎn)
疑難解答
圖片精選