我有一个列表-myList - 其中每个元素都是一个字典。我希望迭代这个列表,但我只对每个字典中的一个属性 - “年龄”感兴趣。我也有兴趣保持迭代次数。
我做:
for i, entry in enumerate(myList):
print i;
print entry['age'];
但是想知道是否有更多的pythonic。有什么提示吗?
答案 0 :(得分:31)
您可以使用生成器来抓住年龄。
# Get a dictionary
myList = [{'age':x} for x in range(1,10)]
# Enumerate ages
for i, age in enumerate(d['age'] for d in myList):
print i,age
而且,是的,不要使用分号。
答案 1 :(得分:22)
非常简单的方法,字典迭代列表
>>> my_list
[{'age': 0, 'name': 'A'}, {'age': 1, 'name': 'B'}, {'age': 2, 'name': 'C'}, {'age': 3, 'name': 'D'}, {'age': 4, 'name': 'E'}, {'age': 5, 'name': 'F'}]
>>> ages = [li['age'] for li in my_list]
>>> ages
[0, 1, 2, 3, 4, 5]
答案 2 :(得分:5)
对于打印,可能你正在做的事情恰到好处。但是如果要存储值,可以使用列表推导:
>>> d_list = [dict((('age', x), ('foo', 1))) for x in range(10)]
>>> d_list
[{'age': 0, 'foo': 1}, {'age': 1, 'foo': 1}, {'age': 2, 'foo': 1}, {'age': 3, 'foo': 1}, {'age': 4, 'foo': 1}, {'age': 5, 'foo': 1}, {'age': 6, 'foo': 1}, {'age': 7, 'foo': 1}, {'age': 8, 'foo': 1}, {'age': 9, 'foo': 1}]
>>> ages = [d['age'] for d in d_list]
>>> ages
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> len(ages)
10
答案 3 :(得分:3)
Python中不需要行末尾的分号(但如果要在同一行上放置多个语句,则可以使用它们)。因此省略它们会更加诡计。
但实际的迭代策略很容易理解,而且非常清楚你正在做什么。有其他方法可以做到这一点。但是明确的for循环是完全pythonic。
(Niklas B.的回答不会正是你在做什么:如果你想做那样的事情,格式字符串应该是"{0}\n{1}"
。)