Более обобщенное решение, которое обрабатывает произвольно глубоко вложенные dicts и списки будут:
def dumpclean(obj):
if type(obj) == dict:
for k, v in obj.items():
if hasattr(v, '__iter__'):
print k
dumpclean(v)
else:
print '%s : %s' % (k, v)
elif type(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 type(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 type(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)
Используя эту функцию, выход операционного усилителя выглядит следующим образом:
{
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)
]
}
Надеюсь, это придает определенную ценность следующему человеку, который ищет этот тип функциональности.
Я знаю, что это старый, но я подумал, что стоит отметить, что это не работает, если автомобили [х] целые числа. Это не то, что запросил ОП, поэтому я просто говорю это для всех, кто натыкается на это, полагая, что это решение на одеяле. –
@ DarrelHolt Вы знаете, как заставить его работать с целыми числами? Потому что это проблема, с которой я столкнулся сейчас – theprowler
@theprowler. Ближе всего я могу подобраться к проблеме, если 'cars = {1: 4, 2: 5}' then 'cars [x]' - целое число, отображаемое на ключ 'x', а не набор, сопоставленный с ключом' x'. В этом случае вам не нужно использовать строку 'for y in cars [x]:', потому что есть только одно значение, которое вы извлекаете, если вы не используете что-то вроде списка или набора целых чисел, тогда оно должно работать , Простите, прошло несколько месяцев, поэтому я не могу полностью вспомнить, как я пришел к выводу о моем предыдущем комментарии. Вы можете отправить мне свой код, и я могу понять, не помогаю ли мне. –