2020-08-03 22:40:21 +02:00
|
|
|
"""
|
|
|
|
Copyright (c) 2020 Sdj Geek
|
|
|
|
Voir le fichier LICENSE
|
|
|
|
|
|
|
|
Classe d'accès aux données du site https://public.opendatasoft.com
|
|
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
import requests
|
|
|
|
|
|
|
|
|
|
|
|
def get_ville_from_cog(cog):
|
2020-08-04 08:46:04 +02:00
|
|
|
"""
|
|
|
|
Donne le nom de la commune (et son code postal) correspondant au code officiel géographique (cog) donné en entrée.
|
|
|
|
|
|
|
|
:param cog: le code officiel géographique à convertie
|
|
|
|
:return: le nom de la commune (et son code postal). None si la recherche a échoué.
|
|
|
|
"""
|
|
|
|
# Contacter l'API
|
2020-08-03 22:40:21 +02:00
|
|
|
r = requests.get("https://public.opendatasoft.com/api/records/1.0/search/",
|
|
|
|
params={'dataset': "correspondance-code-insee-code-postal",
|
|
|
|
'q': f"insee_com={cog}",
|
|
|
|
'lang': "fr"},
|
|
|
|
headers={'Accept': "application/json"})
|
2020-08-04 08:46:04 +02:00
|
|
|
# Tester la validité de la réponse
|
2020-08-03 22:40:21 +02:00
|
|
|
try:
|
|
|
|
r.raise_for_status()
|
|
|
|
except requests.HTTPError:
|
|
|
|
print(f"Warning get_ville_from_cog: requests return status {r.headers}")
|
|
|
|
return None
|
2020-08-04 08:46:04 +02:00
|
|
|
# Récupérer le résultat
|
2020-08-03 22:40:21 +02:00
|
|
|
result = r.json()
|
2020-08-04 08:46:04 +02:00
|
|
|
# Si résultat non vide
|
2020-08-03 22:40:21 +02:00
|
|
|
if result['nhits'] > 0:
|
2020-08-04 08:46:04 +02:00
|
|
|
# COMMUNE (CODE POSTAL)
|
2020-08-03 22:40:21 +02:00
|
|
|
return f"{result['records'][0]['fields']['nom_comm']} ({result['records'][0]['fields']['postal_code']})"
|
|
|
|
print(f"Warning get_ville_from_cog: no result returned for cog {cog}")
|
|
|
|
return None
|