如果字典值不存在,JSON解析循环将跳过

时间:2018-07-15 08:06:32

标签: python json parsing

我正在使用OpenStreetMap API通过以下代码提取有关特定区域的一些数据:

import requests
import json

overpass_url = "http://overpass-api.de/api/interpreter"
overpass_query = """
[out:json];
area["ISO3166-1"="DE"][admin_level=2];
(node["amenity"="place_of_worship"](area);
 way["amenity"="place_of_worship"](area);
 rel["amenity"="place_of_worship"](area);
);
out center;
"""
response = requests.get(overpass_url, 
                        params={'data': overpass_query})
data = response.json()

然后我尝试使用以下代码打印出上面所有的“名称”:

for tags in data['elements']:
    print(tags['tags']['name'])

这对于前12个左右的结果很好用,但是在“标签”字典中没有“名称”值的结果时遇到问题:

Epiphanias Kirche
Kirche St. Bilhildis
Kleine Kreuzkirche
Marienkapelle
Kath. Kirche Heilige Familie
St. Cyriakus
Friedhofskapelle
Ev. Hoffnungsgemeinde / Philippuszentrum
Petrikirche
Sankt Paulus
Kapelle Höver
Pfarrkirche St. Laurentius

---------------------------------------------------------------------------
KeyError                                  Traceback (most recent call last)
<ipython-input-81-5758361aa6f2> in <module>()
      1 for tags in data['elements']:
----> 2     print(tags['tags']['name'])
      3 
      4 #error occurs because not all have name tags

KeyError: 'name'

有没有一种方法可以跳过所有缺少的“名称”值而仅继续解析?

1 个答案:

答案 0 :(得分:1)

尝试使用dict.get

例如:

for tags in data['elements']:
    print(tags['tags'].get('name'))

您还可以设置默认值。例如:print(tags['tags'].get('name', "EMPTY"))