Skip to main content

Outils de lecture/écriture des flux

Project description

Electriflux

Electriflux est une bibliothèque Python conçue pour la lecture et l'écriture des flux de données Enedis.

Fonctionnalités principales

  • Téléchargement sécurisé des fichiers via SFTP
  • Décryptage des fichiers chiffrés
  • Extraction des données XML en DataFrame pandas
  • Configuration flexible des flux via des fichiers YAML

Installation

pip install electriflux

Utilisation

Il y a deux phases :

  1. Récupération et décryptage des fichiers depuis le sFTP :

Assuré par la fonction download_decrypt_extract_new_files de electriflux.utils. Elle prend notamment en entrée un dictionnaire de configuration, qui doit contenir les clés suivantes :

  • 'FTP_ADDRESS',
  • 'FTP_USER',
  • 'FTP_PASSWORD'
  • 'AES_KEY'
  • 'AES_IV'

A l'issue de cette opération, le dossier local choisi contient les fichiers XML des flux déchiffrés.

  1. Extraction des données XML en DataFrame pandas :

Cette extraction des données est assurée par process_flux de electriflux.simple_reader. Son principe est simple, un fichier de configuration en YAML permet de définir, pour chaque flux, des couples clé-valeur, la clé représentant le nom de la colonne à remplir, et la valeur le chemin XPATH vers la donnée à extraire. (C'est un poil plus complexe en réalité, mais c'est l'idée). Par défaut, le fichier simple_flux.yaml est utilisé, mais il est possible d'en utiliser un autre en passant son chemin en argument de process_flux.

Exemple type pour récupérer les données du flux C15 sous forme de csv :

   df = process_flux('C15', Path('~/data/flux_enedis_v2/C15').expanduser())
   df.to_csv('C15.csv', index=False)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

electriflux-0.3.0.tar.gz (19.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

electriflux-0.3.0-py3-none-any.whl (22.3 kB view details)

Uploaded Python 3

File details

Details for the file electriflux-0.3.0.tar.gz.

File metadata

  • Download URL: electriflux-0.3.0.tar.gz
  • Upload date:
  • Size: 19.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.0.1 CPython/3.12.3 Linux/5.15.167.4-microsoft-standard-WSL2

File hashes

Hashes for electriflux-0.3.0.tar.gz
Algorithm Hash digest
SHA256 e855b2c7daf5e73e62c954f149ed13a2fee59835c9698cc508cb94ebcf8b8ab3
MD5 943fec593fc8faf4f5727ffdcb95bbf1
BLAKE2b-256 2b95ce6d199f8e1d2504b6a9ea0ae316a6ea2e076cc6af17af5d1e83581aef7c

See more details on using hashes here.

File details

Details for the file electriflux-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: electriflux-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 22.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.0.1 CPython/3.12.3 Linux/5.15.167.4-microsoft-standard-WSL2

File hashes

Hashes for electriflux-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 317584f7278ea61c5e8a5b188c8c286e948b0aed4799369e560c390fa95fedb8
MD5 ef86292b3de0872dc9ac0e8a60354060
BLAKE2b-256 fc75f025c2c31df02b068de9a3a9e062c06752a98439be07df19557e272efd18

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page