如何在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 

我刚开始学习字典,所以我不知道如何做到这一点。

 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 

处理任意深度嵌套的字典和列表的更通用的解决scheme是:

 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 

我遇到了类似的需求,并为自己开发了一个更强大的function。 我把它包括在这里,以防它可能对另一个有价值。 在运行nosetest时,我还发现能够在调用中指定输出stream,以便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的要求解决scheme产生这样的结果:

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

我希望这为下一个寻找这种function的人提供了一些价值。

你可以使用这个json模块。 本模块中的dumpsfunction将JSON对象转换为格式正确的string,然后可以打印。

 import json cars = {'A':{'speed':70, 'color':2}, 'B':{'speed':60, 'color':3}} print(json.dumps(cars, indent = 4)) 

输出看起来像

  {
     “一个”: {
         “颜色”:2,
         “速度”:70
     },
     “B”:{
         “颜色”:3,
         “速度”: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 

正如Martijn Pieters在上面的评论中提到的那样,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 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代码

 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