โซลูชันที่มีการวางนัยทั่วไปมากขึ้นที่จัดการ dicts และรายการที่ซ้อนกันโดยพลการจะ:
def dumpclean(obj):
if isinstance(obj, dict):
for k, v in obj.items():
if hasattr(v, '__iter__'):
print k
dumpclean(v)
else:
print '%s : %s' % (k, v)
elif isinstance(obj, list):
for v in obj:
if hasattr(v, '__iter__'):
dumpclean(v)
else:
print v
else:
print obj
สิ่งนี้สร้างผลลัพธ์:
A
color : 2
speed : 70
B
color : 3
speed : 60
ฉันวิ่งเข้าไปในความต้องการที่คล้ายกันและพัฒนาฟังก์ชั่นที่มีประสิทธิภาพมากขึ้นเช่นการออกกำลังกายสำหรับตัวเอง ฉันรวมมันไว้ที่นี่ในกรณีที่มันอาจจะมีค่าต่อผู้อื่น ในการรัน nosetest ฉันยังพบว่ามีประโยชน์ที่จะสามารถระบุเอาต์พุตสตรีมในการโทรเพื่อให้สามารถใช้ sys.stderr แทน
import sys
def dump(obj, nested_level=0, output=sys.stdout):
spacing = ' '
if isinstance(obj, dict):
print >> output, '%s{' % ((nested_level) * spacing)
for k, v in obj.items():
if hasattr(v, '__iter__'):
print >> output, '%s%s:' % ((nested_level + 1) * spacing, k)
dump(v, nested_level + 1, output)
else:
print >> output, '%s%s: %s' % ((nested_level + 1) * spacing, k, v)
print >> output, '%s}' % (nested_level * spacing)
elif isinstance(obj, list):
print >> output, '%s[' % ((nested_level) * spacing)
for v in obj:
if hasattr(v, '__iter__'):
dump(v, nested_level + 1, output)
else:
print >> output, '%s%s' % ((nested_level + 1) * spacing, v)
print >> output, '%s]' % ((nested_level) * spacing)
else:
print >> output, '%s%s' % (nested_level * spacing, obj)
เมื่อใช้ฟังก์ชั่นนี้เอาต์พุตของ OP จะเป็นดังนี้:
{
A:
{
color: 2
speed: 70
}
B:
{
color: 3
speed: 60
}
}
ซึ่งฉันเองพบว่ามีประโยชน์และเป็นคำอธิบายมากขึ้น
รับตัวอย่างเล็กน้อยที่ไม่ค่อยน่าสนใจของ:
{"test": [{1:3}], "test2":[(1,2),(3,4)],"test3": {(1,2):['abc', 'def', 'ghi'],(4,5):'def'}}
สหกรณ์วิธีการแก้ปัญหาขออัตราผลตอบแทนนี้:
test
1 : 3
test3
(1, 2)
abc
def
ghi
(4, 5) : def
test2
(1, 2)
(3, 4)
ในขณะที่รุ่น 'ปรับปรุง' ให้ผลดังนี้:
{
test:
[
{
1: 3
}
]
test3:
{
(1, 2):
[
abc
def
ghi
]
(4, 5): def
}
test2:
[
(1, 2)
(3, 4)
]
}
ฉันหวังว่านี้ให้ค่าบางอย่างเพื่อให้คนต่อไปที่กำลังมองหาชนิดของการทำงานนี้