Skip to content

Projet d'enrichissement des données essentielles de la commande publique

Notifications You must be signed in to change notification settings

AchazRyus/decp-augmente

 
 

Repository files navigation

CircleCI

decp augmenté - logo

PROJET DECP - Données Essentielles de la Commande Publique

Description

Les éléments nécessaires

Version

Pour l'instant (28/08/2020) le script est fonctionnel uniquement sur Python 3.7 et Spyder 3.3.6. Une version mise à jour est en implémentation pour Python 3.8 et Syper 4.

Les librairies Python utilisées

pandas numpy json os time tqdm lxml requests logging pickle (optionel)
selenium urllib scikit-learn scipy matplotlib folium colorama math bokeh

Données

JSON

Le fichier des DECP utilisé dans ce projet est en format JSON, il se nomme : 'decp.json'. Ce fichier est mis à jour régulièrement sur le site de data.gouv : https://www.data.gouv.fr/fr/datasets/fichiers-consolides-des-donnees-essentielles-de-la-commande-publique/

CSV

Plusieurs données sous format csv - xlsx sont nécessaires afin d'enrichir les données :

GEOJSON

Pour réaliser la représentation graphique des données, ségmentée par régions et départements, certaines donneés en geojson sont récupérées directement via leur URL.

Webdriver

Afin d'optimiser l'enrichissement via le code siret/siren, une partie des données sont récupérées via une méthode de scraping sur le site infogreffe.fr. Pour une partie du code, le fichier exécutable geckodriver.exe est obligatoire.

To Do

  • Posséder tous les éléments cités ci-dessus
  • Changer le chemin indiquer dans le code à la ligne 39 (mettre le chemin où se situe le code et les données)
  • S'assurer que les données sont dans les bons sous-chemins (le fichier decp.zip permet de vérifier cela)
  • Dans le dossier confs, le fichier var_to_export correspond à toutes les variables dans le DataFrame decp avant export final.
    • Mettre à 1 les colonnes que l'on souhaite exporter
    • 0 Sinon.
  • Exécuter tout le code

Valorisation de la donnée

Nettoyage

Explication de l'ensemble du traitement réalisé pour la partie nettoyage des données.

Travail sur les titulaires

Au sein des decp on distingue deux types de données: les marchés et les concessions. Nous avons donc fusionner les colonnes comportant des informations semblables.

  • La colonne concessionnaire a fusionné avec la colonne titulaire
  • La colonne valeur globale a fusionné avec la colonne montant
  • La colonne autoriteConcedante.id a fusionné avec la colonne acheteur.id
  • La colonne autoriteConcedante.nom a fusionné avec la colonne acheteur.nom
  • On ne conserve que les données ou un titulaire est renseigné.

Travail sur les montants

Dans un soucis de conservation de l'information source, la colonne montant est renomée en montantOriginal et l'ensemble des opérations suivantes seront appliquées à la colonne montantCalcule.

  • Les valeurs manquantes sont remplacées par 0
  • Les montants inférieurs à 200€ et supérieur à 999 999 999€ sont remis à 0
  • Les montants composés d'au moins 5 fois le même chiffre (hors 0) sont remis à 0.

Travail sur des codes manquants

Ce qui est appelé code correspond aux variables d'identifications. On parle ici aussi bien de la viariable id (identifiant des lignes de la base), que id.Titulaires (ientifiant des entreprises) ou encore code_CPV permettant l'identification des types de marchés.

  • Remplacement des valeurs manquantes de id par '0000000000000000' (la colonne id sera retravaillé un peu plus tard dans le processus de nettoyage)
  • Rerait des caractères spéciaux présent dans idTitulaires. On obtient le numéro SIRET
  • Récupération du NIC et stockage dans une colonne nic
  • Création d'une colonne CPV_min composé des deux premiers chiffre du code CPV. Cela permet d'identifier le type de marché (Fournitures/Travaux/Services)

Travail sur les régions

Récupération des codes de départements des marchés. On en profite pour ajouter les libellés et la région.

  • Extraction du code département de la colonne lieuExecution.code et stocké dans codeDepartementExecution
  • Ajout du libellé du département / code de la région / libellé de la région respectivement dans libelleDepartementExecution, codeRegionExecution et libelleRegionExecution

Travail sur les dates

  • Récupération de l'année et du mois de notification du marché et stockage dans anneeNotification et moisNotification
  • Remplacement par np.NaN des dates lorsque l'années est inférieur à 1980 et supérieur à 2100

Travail sur la durée du marché

Au sein des DECP les durées de marché sont exprimées en mois. De même que pour les montants, on conserve les durées initiales et on modifie les durées dans la colonne dureeMoisCalculee. De plus, on ajoute la colonne dureeMoisEstimee: Booléenne, la durée est elle estimée ?
Les durées corrigées sont celles :

  • manquantes: corrigées à 0

Tous les cas suivant seront corrigées en divisant par 30 (conversion en mois)

  • durée égale au montant
  • montant / durée < 100
  • montant / durée < 1000 pour une durée > 12 mois
  • duréee == 30 ou 31 et montant < 200 000
  • duréee == 360 ou 365 ou 366 et montant < 10 000 000
  • durée > 120 et montant < 2 000 000

Un début de travail sur de l'imputation a aussi été réalisé. On se place dans le cas des marchés qui ne sont pas des travaux (CPV_min != 45) et qui ont une duréeCalculee supérieure à 120.
- Imputation par la médiane des durées de mois pour un CPV_min équivalent.

Travail sur la variable qualitative objet.

Remplacement du caractère '�' par 'XXXXX' dans la colonne objet

Enrichissement des données

La partie enrichissement des données va nous permettre d'ajouter, grâce à des sources externes, de la donnée dans nos DECP. Pour cela nous utiliserons les sources de données suivantes:

  • INSEE
    • Code des régions, départements, arrondissements, cantons.
    • La base SIREN
  • OpenDatasoft
    • Géolocalisations des communes
  • SIMAP (Système d'Information pour les MArchés Publics)
    • Nomencalture européenne des codes CPV

Réalisation d'un dashboard

Un dashboard a été fait et est disponible ici

Decp-augmente-v2

Cette partie a pour objectif de décrire et préciser les tenants et aboutissants de la branche feat_v2 du projet en PR. L'objectif principal est d'adapter le processus decp-augmente qui prenait en entrée le fichier créé par decp-rama pour qu'il soit capable de prendre en entrée le fichier fourni par decp-rama-v2.

Modifications de traitement

Il existe certaines modifications du code de nettoyage.py par exemple qu iont pour objectif de rendre le code plus lisible et de l'adapter au fichier en sortie de decp-rama-v2. La plupart des modifications servent à gérer des exeptions générées par des certaines colonnes dans certaines sources.

Modification de la CI

La CI mise en place repose sur les mêmes outils que pour decp-rama-v2 (https://github.com/139bercy/decp-rama-v2) : Dans l'objectif de remplacement de decp-rama, decp-rama-v2 dispose d'une CI qui permet de publier automatiquement le résultat de son script de manière journalière. Tous les jours, la CI va :

  • Lancer un docker via Github Action qui s'appuie sur une image publiée sur DockerHub. Cette image est générée via le DockerFile dans le dossier docker/ et publiée grâce au script publish_docker.sh dans decp-rama-v2.
  • Récuperer le dossier github via actions/checkout@v2.
  • Installer les dépendances nécessaires aux scripts de decp-augmente.
  • Téléchargement des références qui serviront à l'enrichissement.
  • Téléchargement du fichier decp.json produit par decp.json présent sur le serveur ftp de data.eco.
  • Lancer main.py
  • Publier sur le serveur FTP de economie.gouv dans le dossier decp/test le résultat du script : decp_augmente.csv

Problèmes et pistes d'améliorations

Decp-augmente feat_v2 n'est aujourd'hui pas en état pour faire tourner le script à partir du fichier produit par decp-rama-v2. En effet, des erreurs apparaissent et un travail de correction de bugs est nécessaire. Par la durée du téléchargement des données et du processus avant d'obtenir une erreur, il est difficile de repérer et tester des solutions. Voici les différentes pistes de solution de ces problèmes et d'améliorations possibles :

  • Travail d'optimisation des performances de decp-augmente feat_v2. Même en utilisant un fichier témoin decp.json de 30 marches seulement, la durée de traitement reste importante. Il est donc nécessaire d'opérer à des changements sur decp-augmente afin de réduire la longueur des traitements.
  • Mise en cache des références et des dépendances afin de gagner en performance et en répidité d'exécution.
  • Publication des résultats qui ne seraient présents que sur le serveur ftp si le script arrivait à tourner entièrement.

About

Projet d'enrichissement des données essentielles de la commande publique

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 99.5%
  • Shell 0.5%