Merge branch '10-code-geo' into 'master'

Convertir les code insee en nom de ville

Closes #10

See merge request sdjgeek/purge-registres-deces-insee!5
This commit is contained in:
Sdj Geek 2020-08-04 08:47:46 +02:00
commit 35d82173c6
3 changed files with 66 additions and 0 deletions

View File

@ -1,5 +1,8 @@
# Changelog
### [v7.0] 2020-08-04
- Convertit les Codes Officiels Géographiques en nom de commune.
### [v6.1] 2020-07-30
- BUG: Lorsque maiden_name est None, ne pas essayer de le strip

View File

@ -5,6 +5,7 @@ Voir le fichier LICENSE
"""
from abc import ABC, abstractmethod
from site_opendatasoft import get_ville_from_cog
class MembreBase(ABC):
@ -55,6 +56,29 @@ class MembreBase(ABC):
self.i_jour_deces = insee.jour_deces
self.i_ville_deces = insee.code_lieu_deces
def convertir_villes_insee(self):
old_value = self.i_ville_naissance
new_value = None
try:
int(self.i_ville_naissance)
except ValueError:
pass
else:
new_value = get_ville_from_cog(self.i_ville_naissance)
if new_value is not None:
self.i_ville_naissance = new_value
if old_value == self.i_ville_deces:
self.i_ville_deces = new_value
else:
try:
int(self.i_ville_deces)
except ValueError:
pass
else:
new_value = get_ville_from_cog(self.i_ville_deces)
if new_value is not None:
self.i_ville_deces = new_value
def get_texte_decede(self):
if self.r_sexe == "F":
feminin = "e"
@ -62,6 +86,7 @@ class MembreBase(ABC):
feminin = ""
else:
feminin = "(e)"
self.convertir_villes_insee()
return f"""
Le membre {self.get_nom_registres()} ({self.r_id}),
{feminin} le {self.r_jour:0>2}/{self.r_mois:0>2}/{self.r_annee:0>4} à {self.r_ville.upper()}

View File

@ -0,0 +1,38 @@
"""
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):
"""
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
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"})
# Tester la validité de la réponse
try:
r.raise_for_status()
except requests.HTTPError:
print(f"Warning get_ville_from_cog: requests return status {r.headers}")
return None
# Récupérer le résultat
result = r.json()
# Si résultat non vide
if result['nhits'] > 0:
# COMMUNE (CODE POSTAL)
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