Как правильно анализировать вложенный вывод JSON из вызова API в PythonPython

Программы на Python
Ответить
Anonymous
 Как правильно анализировать вложенный вывод JSON из вызова API в Python

Сообщение Anonymous »

Я потратил несколько часов на поиск и чтение статей и предложений, но безрезультатно, надеясь, что кто-нибудь укажет мне на учебник, который, по крайней мере, имеет аналогичный вывод JSON, который мне нужно обработать. Любой учебник, который я читал по этому поводу, посвящен простым парам ключ/значение в простом выводе JSON. Моя цель, если я правильно понимаю, загрузить весь вывод JSON в словарь Python, для чего я затем смогу выполнить итерацию с помощью цикла for, чтобы вывести мои выборки в желаемом порядке. Я пытаюсь напечатать почасовую погоду в формате «текущий час», за которым следует «текущая температура». Необходимо вывести 24 строки. Результат приведенного ниже кода:

Код: Выделить всё

time
temperature_2m
precipitation_probability
precipitation
weather_code
но мне действительно нужны значения этих ключей, а не сами ключи.
Когда я пытаюсь:

Код: Выделить всё

print(hour)["time"]
Я получаю:

Код: Выделить всё

Traceback (most recent call last):
File "/home/bthuy/briefing/weather.py", line 40, in 
print(hour["time"])
~~~~^^^^^^^^
TypeError: string indices must be integers, not 'str'
Думаю, я просто (пока) недостаточно понимаю, как использовать словарь, или, может быть, я путаю словари и списки в Python и объекты и массивы в JSON, я пробовал следовать многочисленным примерам но все они не дают мне желаемого результата: 24 строки вывода, показывающие час и значение температуры для этого часа.

Код: Выделить всё

import requests
import json
from datetime import datetime

url = "https://api.open-meteo.com/v1/forecast"

params = {
"latitude": 37.897,
"longitude": -91.129,
"hourly": ["temperature_2m", "precipitation_probability", "precipitation", "weather_code"],
"temperature_unit": "fahrenheit",
"wind_speed_unit": "mph",
"precipitation_unit": "inch",
"forecast_days": 1
}

response = requests.get(url, params)

body_dict = response.json()
#print (body_dict)
#pretty_json = json.dumps(body_dict, indent=4)
#print (pretty_json)

hourly = body_dict["hourly"]
for hour in hourly:
print (hour)
Вот содержимое body_dict:

Код: Выделить всё

{'elevation': 191.0,
'generationtime_ms': 0.06103515625,
'hourly': {'precipitation': [0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0],
'precipitation_probability': [0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0],
'temperature_2m':  [50.5,
49.8,
47.9,
46.6,
45.9,
45.3,
43.6,
43.2,
45.3,
50.0,
54.6,
57.7,
61.7,
63.9,
65.7,
67.1,
66.3,
62.7,
57.7,
54.6,
52.5,
51.4,
50.4,
49.2],
'time': ['2024-11-22T00:00',
'2024-11-22T01:00',
'2024-11-22T02:00',
'2024-11-22T03:00',
'2024-11-22T04:00',
'2024-11-22T05:00',
'2024-11-22T06:00',
'2024-11-22T07:00',
'2024-11-22T08:00',
'2024-11-22T09:00',
'2024-11-22T10:00',
'2024-11-22T11:00',
'2024-11-22T12:00',
'2024-11-22T13:00',
'2024-11-22T14:00',
'2024-11-22T15:00',
'2024-11-22T16:00',
'2024-11-22T17:00',
'2024-11-22T18:00',
'2024-11-22T19:00',
'2024-11-22T20:00',
'2024-11-22T21:00',
'2024-11-22T22:00',
'2024-11-22T23:00'],
'weather_code': [0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
1,
2]},
'hourly_units': {'precipitation': 'inch',
'precipitation_probability': '%',
'temperature_2m': '°F',
'time': 'iso8601',
'weather_code': 'wmo code'},
'latitude': 37.89382,
'longitude': -91.12241,
'timezone': 'America/Chicago',
'timezone_abbreviation': 'CST',
'utc_offset_seconds': -21600}
Кроме того, тем временем я обнаружил, что мне нужно добавить «.values()», чтобы получать только значения, а не ключи:

Код: Выделить всё

hourly = body_dict["hourly"]

for hour in hourly.values():
print (hour)
который выводит значения времени и температуры_2m:

Код: Выделить всё

['2024-11-22T00:00', '2024-11-22T01:00', '2024-11-22T02:00', '2024-11-22T03:00', '2024-11-22T04:00', '2024-11-22T05:00', '2024-11-22T06:00', '2024-11-22T07:00', '2024-11-22T08:00', '2024-11-22T09:00', '2024-11-22T10:00', '2024-11-22T11:00', '2024-11-22T12:00', '2024-11-22T13:00', '2024-11-22T14:00', '2024-11-22T15:00', '2024-11-22T16:00', '2024-11-22T17:00', '2024-11-22T18:00', '2024-11-22T19:00', '2024-11-22T20:00', '2024-11-22T21:00', '2024-11-22T22:00', '2024-11-22T23:00']
[50.5, 49.8, 47.9, 46.6, 45.9, 45.3, 43.6, 43.2, 45.3, 50.0, 54.6, 57.7, 61.7, 63.9, 65.7, 67.1, 66.3, 62.7, 57.7, 54.6, 52.5, 51.4, 50.4, 49.2]
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
[0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0]
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 3]
Мне нужно повторить их еще раз, чтобы результат стал следующим:

Код: Выделить всё

2024-11-22T00:00 50.5
2024-11-22T01:00 49.8
но здесь я застрял: я не могу найти способ выбрать значения времени и температуры_2m в цикле for и распечатать их.< /п>

Подробнее здесь: https://stackoverflow.com/questions/792 ... -in-python
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Python»