我有一个变量和从excel导入的列表,如下所示:
cities= [{'City': 'Buenos Aires',
'Country': 'Argentina',
'Population': 2891000,
'Area': 4758},
{'City': 'Toronto',
'Country': 'Canada',
'Population': 2800000,
'Area': 2731571},
{'City': 'Pyeongchang',
'Country': 'South Korea',
'Population': 2581000,
'Area': 3194},
{'City': 'Marakesh', 'Country': 'Morocco', 'Population': 928850, 'Area': 200},
{'City': 'Albuquerque',
'Country': 'New Mexico',
'Population': 559277,
'Area': 491},
{'City': 'Los Cabos',
'Country': 'Mexico',
'Population': 287651,
'Area': 3750},
{'City': 'Greenville', 'Country': 'USA', 'Population': 84554, 'Area': 68},
{'City': 'Archipelago Sea',
'Country': 'Finland',
'Population': 60000,
'Area': 8300},
{'City': 'Walla Walla Valley',
'Country': 'USA',
'Population': 32237,
'Area': 33},
{'City': 'Salina Island', 'Country': 'Italy', 'Population': 4000, 'Area': 27},
{'City': 'Solta', 'Country': 'Croatia', 'Population': 1700, 'Area': 59},
{'City': 'Iguazu Falls',
'Country': 'Argentina',
'Population': 0,
'Area': 672}]
我只想要每个城市的“人口”值。 从每个城市“人口”中列出价值的最有效或最简便的方法是什么?
下面是我想出的代码,但是效率很低。
City_Population = [cities[0]['Population'], cities[1]['Population'], cities[2]['Population']]
我目前正在学习Python,任何建议都会有所帮助!
谢谢!
答案 0 :(得分:3)
使用列表理解:
print([city['Population'] for city in cities])
输出:
[2891000, 2800000, 2581000, 928850, 559277, 287651, 84554, 60000, 32237, 4000, 1700, 0]
编辑:
假设population
中没有city
:
print([city['Population'] for city in cities if 'Population' in city])
输出(列表中一些城市的人口迁移):
[2891000, 2800000, 2581000, 928850, 287651, 84554, 32237, 4000]
答案 1 :(得分:0)
使用吸气剂,这样,如果其中一些未定义,您将拥有空/无值。
populations = [city.get('Population') for city in cities]
如果您不想使用空值:
populations = [pop for pop in populations if pop is not None]