У меня есть следующий пример кода, который анализирует файл JSON из API.
for query in r["queries"]:
print(query["attributes"]["planning_wait_time"])
Это дает мне результат:
5986
5987
42
0
63
5978
Traceback (most recent call last):
File "./query_warning.py", line 24, in <module>
print(query["attributes"]["planning_wait_time"])
KeyError: 'planning_wait_time'
Числа, которые вы видите, являются правильными числами для Planning_wait_time, я могу только предположить, что причина, по которой я получаю KeyError, заключается в том, что не вся информация в моем тексте JSON включает планирование_wait_time. Есть ли способ обойти ошибку? Мне нужны результаты только в том случае, если в JSON есть Planning_wait_time Спасибо
@ozcanyarimdunya именно то, что мне нужно. Спасибо
Пожалуйста. Удачного кодирования :)






Проверить ключ
for q in r["queries"]:
attrs = q["attributes"]
if "planning_wait_time" in attrs:
print(attrs["planning_wait_time"])
Или, если вы согласны с None или хотите что-то еще, используйте .get()
for q in r["queries"]:
print(q["attributes"].get("planning_wait_time")) # You can add a parameter here for a default value
query ["attributes"]. get ("scheme_wait_time") может работать. С помощью этого метода get он возвращает None, если такого ключа нет, поэтому вы можете добавить здесь условие if