Pythonで行ごとに辞書を印刷する方法は?


166

これは辞書です

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

辞書の勉強を始めたばかりなので、どうすればいいのかわかりません。

回答:


142
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

12
私はこれが古いことを知っていますが、cars [x]が整数の場合、これは機能しないことを言及する価値があると思いました。それはOPが要求していたものではないので、それが包括的な解決策であると仮定してこれにつまずく誰かのためにそれを言っているだけです。
ダレルホルト

@DarrelHolt整数で動作させる方法を知っていますか?それは私が現在直面してる問題だからです
theprowler

最も近い@theprowler私は、問題を再作成に得ることができる場合でcars = {1:4, 2:5}、その後cars[x]のキーにマッピングされた整数であるxのではなく、キーにマッピングされたセットx。この場合、for y in cars[x]:取得する値は1つしかないため、行を使用する必要はありません。リストや整数のセットなどを使用している場合を除き、機能するはずです。申し訳ありませんが、数か月が経過しているため、以前のコメントの結論に至った経緯を完全に思い出せません。コードを送っていただければ、私が助けてくれるかどうかを確認できます。
ダレルホルト2016

うーん。私の問題はそれよりもさらに悪いと思います。基本的に、HTMLテーブルからいくつかのデータを解析して、たまたまそれをディクショナリに格納しました。今、そのディクショナリデータを取得して、それをすべてOracleテーブルにエクスポートする前にDataFrameに入れようとしています。 ...私はかなり詳細に知っていますが、今私を保持しているステップは、データをDataFrameに入れることです...私の辞書は何らかの理由で1つのキーを持ち、すべてのデータが値であるため、難しいです行と列にきちんとそれを置くしようとしている...
theprowler

118

このためにjsonモジュールを使用できます。dumpsこのモジュールの関数は、JSONオブジェクトを適切にフォーマットされた文字列に変換し、それを出力できます。

import json

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

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

出力は次のようになります

{
    "A":{
        「色」:2、
        「速度」:70
    }、
    "B":{
        「色」:3、
        「速度」:60
    }
}

ドキュメントはまた、この方法のための便利なオプションの束を指定します。


2
true、dictのコンテンツはjsonにシリアル化可能である必要がありますが、ここで提供される出力は、pprint.PrettyPrinterによって生成される出力よりもはるかにクリーンです(たとえば、人間が読める)。具体的には、一貫したインデントと、u'foo 'などの文字列プレフィックスの破棄の領域です。
Buffalo Rabor

私がやるprint(json.dumps(cars, indent=4, ensure_ascii=False))そうでない場合は、非ASCII文字が読めなくしているため。
ボリス

85

任意に深くネストされた辞書およびリストを処理するより一般的なソリューションは次のとおりです。

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

これがこのタイプの機能を探している次の人に何らかの価値を提供することを願っています。


11
また、形式が厳しくない場合は、「print json.dumps(obj、indent = 3)」を使用することもできます。タプルをキーとして使用しているため、それほど重要ではない例では(私の環境では)窒息しますが、これはほとんどの構造の合理的な表現になります...
MrWonderful

7
では、なぜpprint.pprint()ここで使用しないのですか?
Martijn Pieters

1
ほぼJSONクリエーターになりましたね。
user2007447

30

ネストされた構造があるので、ネストされた辞書もフォーマットする必要があります。

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

28

pprint.pprint() この仕事に適したツールです:

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


4

これは、ツリーに2つのレベルしかないことがわかっている場合に機能します。

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

4

次のワンライナーを確認してください。

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

いいものですが、これをで使用できるように変換しようとしましたsys.modulesが、失敗しました。やってみませんか?
not2qubit 2018年

4

私はきれいなフォーマットを好むyaml

import yaml
yaml.dump(cars)

出力:

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

pip install PyYAML最初にする必要があります。
ボリス

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

0
# 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

0

これが私の問題の解決策です。アプローチは似ていると思いますが、他のいくつかの回答よりも少し単純です。また、任意の数のサブディクショナリが可能であり、任意のデータ型で機能するようです(関数として値を持つディクショナリでテストしました)。

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)

-1

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

1
何を変更しましたか?出力は何ですか?
Andreas Haferburg
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.