Beispiel:
Der Code lautet wie folgt:
d = { "root": { "folder2": { "item2": None, "item1": None }, "folder1": { "subfolder1": { "item2": None, "item1": None }, "subfolder2": { "item3": None } } } }
Die schöne Ausgabe ist:
Beachten Sie die Merkmale:
1. Die Tasten derselben Ebene sind linksbündig, d. h. der Einzug ist gleich.
d = { "root": { "folder2": { "item2": None, "item1": None }, "folder1": { "subfolder1": { "item2": None, "item1": None }, "subfolder2": { "item3": None } } } }
2. Ändern Sie die Zeile nach der Nummer.
3. Wenn value ein Wörterbuch ist, also ein verschachteltes Wörterbuch, dann befindet sich das verschachtelte Wörterbuch auf der nächsten Ebene und der Einzug des Schlüssels ist auf jeder Ebene unterschiedlich.
Ideenanalyse:
Dies ist ein „Spleißzeichenfolge“-Problem, die Elemente sind „“{}:,n und Leerzeicheneinzug.“
Durchlaufen Sie jedes (k, v) Schlüssel-Wert-Paar, fügen Sie sie für Yield zusammen und führen Sie eine Rekursion durch, wenn Sie auf ein verschachteltes Wörterbuch stoßen, d. h. Rekursion + Yield.
Laden Sie den Code hoch.
#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)
Weitere Artikel zu benutzerdefinierten Python-Konstruktionsmethoden zur Verschönerung der Ausgabe von Wörterbuchstrukturen finden Sie auf der chinesischen PHP-Website!