如何在 Python 中逐行打印字典?
Posted
技术标签:
【中文标题】如何在 Python 中逐行打印字典?【英文标题】:How to print a dictionary line by line in Python? 【发布时间】:2013-03-25 00:32:55 【问题描述】:这是字典
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
我刚开始学习字典,所以我不知道该怎么做。
【问题讨论】:
【参考方案1】:使用这个。
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
【讨论】:
【参考方案2】:我更喜欢yaml
的简洁格式:
import yaml
print(yaml.dump(cars))
输出:
A:
color: 2
speed: 70
B:
color: 3
speed: 60
【讨论】:
你必须先pip install PyYAML
。
与上面的 pprint
示例不同,当列表嵌套在 dicts 中时,这似乎会中断。
非常好的和紧凑的解决方案。只需添加print
语句。【参考方案3】:
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
【讨论】:
这似乎是迄今为止最简单和最好的解决方案,因为它还可以处理嵌套在 中的 sets、tuples 和 lists >dict.【参考方案4】:这是我对问题的解决方案。我认为它的方法相似,但比其他一些答案要简单一些。它还允许任意数量的子字典,并且似乎适用于任何数据类型(我什至在具有函数作为值的字典上对其进行了测试):
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)
【讨论】:
我看不出这比其他答案更简单。当然不是为了可读性。也很高兴看到一些示例输出。【参考方案5】:处理任意深度嵌套的字典和列表的更通用的解决方案是:
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)
]
我希望这能为下一个寻找此类功能的人提供一些价值。
【讨论】:
如果格式不是太严格,也可以使用'print json.dumps(obj, indent=3)'。这给出了大多数结构的合理表示,尽管由于使用元组作为键,它确实(在我的环境中)在我不太平凡的示例中窒息...... 为什么不在这里使用pprint.pprint()
呢?
差点成为 JSON 创建者,不是吗?【参考方案6】:
# 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
【讨论】:
【参考方案7】:###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]
"""
【讨论】:
【参考方案8】:修改 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
【讨论】:
你修改了什么?输出是什么?【参考方案9】:您可以为此使用json
模块。此模块中的 dumps
函数将 JSON 对象转换为格式正确的字符串,然后您可以打印该字符串。
import json
cars = 'A':'speed':70, 'color':2,
'B':'speed':60, 'color':3
print(json.dumps(cars, indent = 4))
输出看起来像
“一种”: “颜色”:2, “速度”:70 , “乙”: “颜色”:3, “速度”:60documentation 还为此方法指定了许多有用的选项。
【讨论】:
true,dict 的内容必须可序列化为 json,但是,此处提供的输出比 pprint.PrettyPrinter 生成的输出要干净得多(例如,人类可读)。特别是在一致缩进和丢弃字符串前缀(例如 u'foo')方面。 我会print(json.dumps(cars, indent=4, ensure_ascii=False))
因为否则非 ASCII 字符是不可读的。【参考方案10】:
检查以下单行:
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
一起使用,但我失败了。想试试吗?【参考方案11】:
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
【讨论】:
我知道这是旧的,但我认为值得一提的是,如果 cars[x] 是整数,这将不起作用。这不是 OP 所要求的,所以我只是为任何偶然发现此问题的人说它,假设这是一个全面的解决方案。 @DarrelHolt 你知道如何让它与整数一起工作吗?因为这就是我目前面临的问题 @theprowler 最接近重现问题的方法是如果cars = 1:4, 2:5
然后cars[x]
是映射到键x
的整数,而不是映射到键x
的集合。在这种情况下,您不需要使用 for y in cars[x]:
行,因为您要检索的只有一个值,除非您使用的是列表或整数集之类的东西,否则它应该可以工作。抱歉,已经几个月了,所以我不完全记得我是如何得出上一条评论的结论的。你可以把你的代码发给我,我看看能不能帮到你。
嗯。我认为我的问题比这更糟糕。基本上,我已经从 html 表中解析出一些数据,并且碰巧将其存储在字典中,现在我试图将字典数据放入 DataFrame 中,然后再将其全部导出到 Oracle 表中。 ...我知道这很深入,但是现在阻碍我的步骤是将数据放入 DataFrame ....我的字典出于某种原因有一个键,所有数据都在值中,所以很难试图把它整齐地放入行和列中。..【参考方案12】:
如果您知道树只有两个级别,这将起作用:
for k1 in cars:
print(k1)
d = cars[k1]
for k2 in d
print(k2, ':', d[k2])
【讨论】:
【参考方案13】:for car,info in cars.items():
print(car)
for key,value in info.items():
print(key, ":", value)
【讨论】:
【参考方案14】:你有一个嵌套结构,所以你也需要格式化嵌套字典:
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
【讨论】:
以上是关于如何在 Python 中逐行打印字典?的主要内容,如果未能解决你的问题,请参考以下文章