Как напечатать словарь построчно в Python?

Это словарь

cars = {'A':{'speed':70,
        'color':2},
        'B':{'speed':60,
        'color':3}}

Используя это for loop

for keys,values in cars.items():
    print(keys)
    print(values)

Он печатает следующее:

B
{'color': 3, 'speed': 60}
A
{'color': 2, 'speed': 70}

Но я хочу, чтобы программа напечатала это так:

B
color : 3
speed : 60
A
color : 2
speed : 70

Я только начал изучать словари, поэтому я не уверен, как это сделать.

18 ответов

Решение
for x in cars:
    print (x)
    for y in cars[x]:
        print (y,':',cars[x][y])

выход:

A
color : 2
speed : 70
B
color : 3
speed : 60

Вы могли бы использовать json Модуль для этого. dumps Функция в этом модуле преобразует объект JSON в правильно отформатированную строку, которую затем можно распечатать.

import json

cars = {'A':{'speed':70, 'color':2},
        'B':{'speed':60, 'color':3}}

print(json.dumps(cars, indent = 4))

Выход выглядит как

{
    "А": {
        "цвет": 2,
        "скорость": 70
    },
    "B": {
        "цвет": 3,
        "скорость": 60
    }
}

В документации также указывается множество полезных опций для этого метода.

Более обобщенное решение, которое обрабатывает произвольно глубоко вложенные диктанты и списки:

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

Я столкнулся с аналогичной потребностью и разработал более надежную функцию для себя. Я включил это здесь в случае, если это может иметь значение для другого. В ходе проверки носа я также счел полезным указать поток вывода в вызове, чтобы вместо него можно было использовать 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)

Используя эту функцию, вывод 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'}}

Запрошенное решение OP дает это:

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)
   ]
}

Я надеюсь, что это даст некоторую ценность следующему человеку, который ищет этот тип функциональности.

Как отметил Мартин Питерс в одном из комментариев выше, PrettyPrint является хорошим инструментом для этой работы:

>>> import pprint
>>> cars = {'A':{'speed':70,
...         'color':2},
...         'B':{'speed':60,
...         'color':3}}
>>> pprint.pprint(cars, width=1)
{'A': {'color': 2,
       'speed': 70},
 'B': {'color': 3,
       'speed': 60}}

У вас есть вложенная структура, поэтому вам также нужно отформатировать вложенный словарь:

for key, car in cars.items():
    print(key)
    for attribute, value in car.items():
        print('{} : {}'.format(attribute, value))

Это печатает:

A
color : 2
speed : 70
B
color : 3
speed : 60

Я предпочитаю чистое форматирование yaml:

import yaml
yaml.dump(cars)

выход:

A:
  color: 2
  speed: 70
B:
  color: 3
  speed: 60
for car,info in cars.items():
    print(car)
    for key,value in info.items():
        print(key, ":", value)

Это будет работать, если вы знаете, что дерево имеет только два уровня:

for k1 in cars:
    print(k1)
    d = cars[k1]
    for k2 in d
        print(k2, ':', d[k2])

Проверьте следующую однострочную:

print('\n'.join("%s\n%s" % (key1,('\n'.join("%s : %r" % (key2,val2) for (key2,val2) in val1.items()))) for (key1,val1) in cars.items()))

Выход:

A
speed : 70
color : 2
B
speed : 60
color : 3

Я просто добавил немного к ответу @MrWonderful, а также преобразовал его из Python2 в Python3.

В новой версии теперь есть 2 большие функции.

  1. Сепараторы
  2. Префиксы
          def print_pretty(
            obj,
            nested_level=0,
            output=sys.stdout,
            prefixes_at = ["all"],
            prefixes = ["|>"],
            spacing_amount = 4,
            separators_at_every = [0, 1, 2],
            separators = ["|______________\n|", "    |----------", "        |"]
    ):
    
    
        spacing = ''
        for i in range(0, spacing_amount):
            spacing += ' '
    
        if isinstance(obj, dict):
            for k, v in list(obj.items()):
                sep_index = -1
                try:
                    sep_index = separators_at_every.index(nested_level)
                except ValueError as e:
                    pass  # not in list
                if sep_index != -1:
                    print(separators[sep_index])
    
                if hasattr(v, '__iter__') and type(v) != str:
                    text = '%s' % (nested_level * spacing)
                    if len(prefixes) > 0:
                        prefix_index = -1
                        try:
                            prefix_index = prefixes_at.index(nested_level)
                        except:
                            pass
                        if prefix_index != -1 or prefixes_at[0] == "all":
                            text += prefixes[prefix_index]
                    text += '%s:' % k
                    print(text, file=output)
    
                    print_pretty(v, nested_level + 1, output)
                else:
                    text = '%s' % (nested_level * spacing)
    
                    if len(prefixes) > 0:
                        prefix_index = -1
                        try:
                            prefix_index = prefixes_at.index(nested_level)
                        except:
                            pass
                        if prefix_index != -1 or prefixes_at[0] == "all":
                            text += prefixes[prefix_index]
                    text += '%s: %s' % (k, v)
                    print(text, file=output)
    
        elif isinstance(obj, list):
            for v in obj:
                if hasattr(v, '__iter__'):
                    print_pretty(v, nested_level + 1, output)
                else:
                    text = '%s' % (nested_level + 1 * spacing)
    
                    if len(prefixes) > 0:
                        prefix_index = -1
                        try:
                            prefix_index = prefixes_at.index(nested_level)
                        except:
                            pass
                        if prefix_index != -1 or prefixes_at[0] == "all":
                            text += prefixes[prefix_index]
                    text += '%s' % v
                    print(text, file=output)
        else:
            if nested_level > 0:
                nested_level -= 1
            print('%s  > %s' % (nested_level * spacing, obj), file=output)

Пример изображения данных (JSON)

Пример изображения вывода консоли

Также работает двойная итерация вашей конструкции.

      for keys,values in cars.items():
    print(keys)
    for key2,value2 in values.items():
        print(key2,":",value2)

Это так, потому что у вас есть словарь, значения которого являются словарями.

Сделал один вкладыш. Выводит именно то, что вы хотите.

      cars = {'A':{'speed':70,
        'color':2},
        'B':{'speed':60,
        'color':3}}
print('\n'.join(f'{k}\n'+'\n'.join(f'{k2} : {v}' for k2,v in reversed(cars[k].items())) for k in reversed(cars)))

Кроме того, попробовал запустить сtimeitвсе решения. А мой всегда был самым медленным.

Вот мое решение проблемы. Я думаю, что это похоже на подход, но немного проще, чем некоторые другие ответы. Он также позволяет использовать произвольное количество подклассов и, кажется, работает для любого типа данных (я даже тестировал его в словаре, который имел функции как значения):

def pprint(web, level):
    for k,v in web.items():
        if isinstance(v, dict):
            print('\t'*level, f'{k}: ')
            level += 1
            pprint(v, level)
            level -= 1
        else:
            print('\t'*level, k, ": ", v)

Я думаю, что понимание списка - самый чистый способ сделать это:

      mydict = {a:1, b:2, c:3}

[(print("key:", key, end='\t'), print('value:', value)) for key, value in mydict.items()]

Модификация кода MrWonderful

import sys

def print_dictionary(obj, ident):
    if type(obj) == dict:
        for k, v in obj.items():
            sys.stdout.write(ident)
            if hasattr(v, '__iter__'):
                print k
                print_dictionary(v, ident + '  ')
            else:
                print '%s : %s' % (k, v)
    elif type(obj) == list:
        for v in obj:
            sys.stdout.write(ident)
            if hasattr(v, '__iter__'):
                print_dictionary(v, ident + '  ')
            else:
                print v
    else:
        print obj
# Declare and Initialize Map
map = {}

map ["New"] = 1
map ["to"] = 1
map ["Python"] = 5
map ["or"] = 2

# Print Statement
for i in map:
  print ("", i, ":", map[i])

#  New : 1
#  to : 1
#  Python : 5
#  or : 2

Использовать этот.

      cars = {'A':{'speed':70,
        'color':2},
        'B':{'speed':60,
        'color':3}}

print(str(cars).replace(",", ",\n"))

выход:

      {'A': {'speed': 70,
 'color': 2},
 'B': {'speed': 60,
 'color': 3}}
###newbie exact answer desired (Python v3):
###=================================
"""
cars = {'A':{'speed':70,
        'color':2},
        'B':{'speed':60,
        'color':3}}
"""

for keys, values in  reversed(sorted(cars.items())):
    print(keys)
    for keys,values in sorted(values.items()):
        print(keys," : ", values)

"""
Output:
B
color  :  3
speed  :  60
A
color  :  2
speed  :  70

##[Finished in 0.073s]
"""
Другие вопросы по тегам