Programing

파이썬에서 사전을 한 줄씩 인쇄하는 방법?

lottogame 2020. 6. 18. 07:50
반응형

파이썬에서 사전을 한 줄씩 인쇄하는 방법?


이것은 사전입니다

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

방금 사전을 배우기 시작했기 때문에 어떻게 해야할지 모르겠습니다.


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

문서는 또한이 방법에 대한 유용한 옵션의 무리를 지정합니다.


임의로 중첩 된 dicts 및 list를 처리하는보다 일반화 된 솔루션은 다음과 같습니다.

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'}}

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

이것이 다음 유형의 기능을 찾는 다음 사람에게 가치를 제공하기를 바랍니다.


중첩 구조가 있으므로 중첩 사전도 형식화해야합니다.

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

위의 주석 중 하나에서 언급 한 Martijn Pieters가이 작업을위한 좋은 도구입니다.

>>> 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 car,info in cars.items():
    print(car)
    for key,value in info.items():
        print(key, ":", value)

This will work if you know the tree only has two levels:

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

Check the following one-liner:

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()))

Output:

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]
"""

# 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

Modifying MrWonderful code

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

참고URL : https://stackoverflow.com/questions/15785719/how-to-print-a-dictionary-line-by-line-in-python

반응형