Récupérer une information depuis Internet - Niveau facile

Dans ce mini projet, nous allons nous connecter à internet pour récupérer un fichier au format JSON, puis en afficher le contenu. Ce projet est très similaire dans son fonctionnement à celui décrit ici, mais sa mise en oeuvre sera bien plus simple car nous n'utiliserons aucun autre matériel qu'une carte Wemos (ici une ESP32 mais une ESP8266 ferait aussi bien l'affaire).

Nous allons donc afficher le temps qu'il fait dans notre ville. Pour cela, nous utiliserons l'API du site openweathermap.org.

Voici un exemple de ce que l'on obtient lors d'une requête :

https://samples.openweathermap.org/data/2.5/weather?q=London&appid=b6907d289e10d714a6e88b30761fae22

En cliquant sur ce lien avec Firefox par exemple, les données brutes JSON sont mises en forme pour les rendre lisibles. On voit donc que l'on récupère facilement le nom de la ville, les conditions météo actuelles et la température. Ce sont ces informations que l'on va afficher sur notre carte.

Remarque

Pour les besoins de la démonstration, j'utiliserai l'URL d'exemple. Rien n’empêche de créer un compte gratuit sur le site pour récupérer une clé API permettant de personnaliser la requête pour la ville de son choix !

MéthodeLe programme

Voici le programme.

  • La partie Wifi est à supprimer si vous avez fait la connexion dans le boot.py

  • Les codes Wifi sont à compléter

  • L'adresse DATA_SOURCE pourra être remplacée par une vraie contenant un lieu personalisée et une clé API.

Si on enlève la partie Wifi, le code nécessaire est extrêmement simpe et concis !

1
import time
2
import network  # Si connexion dans ce script
3
import sys
4
import urequests
5
6
# Connexion Wifi
7
# Supprimer cette partie si elle est
8
# faite automatiquement au demarrage de la carte
9
# dans le boot.py
10
############################
11
# Debut configuration Wifi #
12
############################
13
WIFI_SSID = "MON_WIFI"
14
WIFI_PASSWORD = "MON_PASSWD"
15
16
# turn off the WiFi Access Point
17
ap_if = network.WLAN(network.AP_IF)
18
ap_if.active(False)
19
20
# connect the device to the WiFi network
21
wifi = network.WLAN(network.STA_IF)
22
wifi.active(True)
23
wifi.connect(WIFI_SSID, WIFI_PASSWORD)
24
25
# wait until the device is connected to the WiFi network
26
MAX_ATTEMPTS = 20
27
attempt_count = 0
28
while not wifi.isconnected() and attempt_count < MAX_ATTEMPTS:
29
    attempt_count += 1
30
    time.sleep(1)
31
32
if attempt_count == MAX_ATTEMPTS:
33
    print("could not connect to the WiFi network")
34
    sys.exit()
35
print(wifi.ifconfig())
36
37
################################
38
# fin de la configuration Wifi #
39
################################
40
41
DATA_SOURCE = "https://samples.openweathermap.org/data/2.5/weather?q=London&appid=b6907d289e10d714a6e88b30761fae22"
42
43
response = urequests.get(DATA_SOURCE)
44
repJson  = response.json()          # repJson est un dictionnaire
45
tempf = repJson['main']['temp']
46
print(repJson['name'])
47
print("Temp : "+str(tempf-273.15))  # Transformation kelvin vers Celsius
48
print(repJson['weather'][0]['description'])

Ce qui donne le résultat ci-contre. La ligne repJson = response.json() permet l'analyse de la réponse au format Json et produit un dictionnaire. A partir de là, il est très simple d'extraire les informations recherchées !

ComplémentPrévisions à 5 jours

Ceci peut servir de base à une station météo affichant des prévisions météo à 5 jours : il suffit juste d'utiliser une autre source de donnée :

DATA_SOURCE="https://samples.openweathermap.org/data/2.5/forecast?id=524901&appid=b6907d289e10d714a6e88b30761fae22"

et adapter les chemins d'accès dans le dictionnaire

tempf=repJson['list'][0]['main']['temp']

print(repJson['city']['name'])

print(repJson['list'][0]['weather'][0]['description'])

Le reste est juste une histoire d'interface homme machine pour une présentation claire de cette masse importante d'information. C'est quelque chose qui serait tout à fait réalisable dans le cadre de SNT voire NSI.

AttentionAttention à la mémoire

L'accès aux prévisions à 5 jours nécessite le téléchargement en mémoire d'un fichier très volumineux. Seule une carte ESP32 sera capable de réaliser cette tâche. La carte ESP8266 affichera un message d'erreur pour cause de mémoire insuffisante.