Simulating annual State grants to the French administrative divisions
Project description
leximpact-dotations-back
Ce dépôt est dédié aux calculs des dotations de l'État aux territoires. Il propose une API web répondant en particulier aux besoins de l'interface définie dans le dépôt leximpact-dotations-ui.
Pré-requis
Ce dépôt requiert le langage Python dans sa version 3.11. Il utilise le gestionnaire de dépendances et de paquetage Poetry.
Gestion de versions de Python multiples avec pyenv
Si votre environnement local dispose déjà d'autres versions de Python, vous pouvez définir une version Python propre à ce dépôt avec pyenv.
Les commandes sont alors pyenv install 3.11 suivie de pyenv local 3.11.
Pour relier la version du langage choisie à l'environnement isolé que créera Poetry, exécuter la commande suivante dans un terminal Shell :
poetry env use python3.11
Installer leximpact-dotations-back
Initialiser la configuration en copiant le modèle de fichier .env :
# dans le répertoire racine du dépôt
# (celui où se trouve ce fichier README.md)
cp .env.example .env
Vérifier que la version de Python associée à Poetry est bien la version attendue :
poetry run python --version
# résultat attendu : Python 3.11.x
Pour installer les dépendances de ce dépôt, exécuter la commande suivante dans un terminal Shell :
poetry install
Ceci créera un environnement virtuel.
Si l'on souhaite voir l'environnement actif, celui-ci est indiqué parmi les environnements existants. Cette commande permet de les lister :
poetry env list
Exécuter leximpact-dotations-back en local
Exécuter leximpact-dotations-back revient à exécuter son API web grâce à la commande suivante :
# mode développement
poetry run fastapi dev leximpact_dotations_back/main.py
# mode production
poetry run fastapi run leximpact_dotations_back/main.py
L'API est alors disponible à l'adresse locale suivante : http://127.0.0.1:8000
Sa documentation est automatiquement générée et accessible à l'adresse : http://127.0.0.1:8000/docs
Exécuter les tests
Pour vérifier les résultats des tests unitaires, exécuter la commande suivante :
poetry run pytest
Il est possible d'afficher les résultats de print avec l'option -s. Exemple sur un fichier de test :
poetry run pytest tests/2022/test_criteres_2022_2024.py -s
Par ailleurs, les traces de leximpact_dotations_back sont gérées avec la librairie logging. Si l'on souhaite les afficher durant l'exécution des tests, exécuterles alors cette commande (ici pour les messages de niveau DEBUG) :
poetry run pytest --log-cli-level=DEBUG
Pour les tests d'API web, se référer au README_API.
Ajuster le style du code
Vérifier le style du code avec flake8 :
poetry run flake8
Ou vérifier le style du code que vous avez ajouté avec :
poetry run flake8 `git ls-files | grep "\.py"`
Et le corriger automatiquement dans le répertoire courant et récursivement dans son contenu avec :
poetry run autopep8 .
La récursivité de cette commande n'est effective que lorsqu'elle est configuée pour autopep8 dans le fichier pyproject.toml.
Données
La Direction générale des collectivités locales (DGCL), publie en donnée ouverte les critères de répartition des dotations. Ces données évoluent annuellement.
Données DGCL 2023, 2024 et 2025
Par exemple, pour le calcul des dotations de l'année 2024, leximpact-dotations-back utilise le fichier criteres_repartition_2024.csv. Celui-ci est obtenu selon les étapes suivantes :
- le fichier des critères pour la catégorie des communes
criteres_repartition_csv.php.xlsxest téléchargé sur le site officiel, - le fichier est renommé pour indiquer l'année en
criteres_repartition_csv_2024.php.xlsx - puis ce fichier
.xlsxest ouvert dans un tableur (LibreOffice), - l'onglet
Critères de répartitionest sauvegardé en tant que.csvsousdata/raw/criteres_repartition_2024_raw.csv(UTF-8 pour l'encodage, virgule pour les délimitations, double guillemet pour les chaînes de caractères) criteres_repartition_2024_raw.csvest ensuite lu pour produire le fichier finalcriteres_repartition_2024.csvgrâce à la commande suivante :poetry run python data/raw/data_cleanup.py 2024
De même pour 2023 (respectivement 2025) où l'on remplace 2024 par 2023 (respectivement 2025).
Données INSEE 2025
Pour l'initialisation du calcul sur la DCN on emploie les données de l'INSEE, communes depuis 1943 : COG millésime 2025 > Communes depuis 1943 > Téléchargement du CSV.
On obtient alors v_commune_depuis_1943.csv que l'on renomme en insee_commune_depuis_1943.csv.
ℹ️ Note spécifique indiquée par le producteur des données :
"Le décret n°2025-34 du 8 janvier 2025 portant changement du nom de sept communes est entré en vigueur le 11 janvier 2025. Ces modifications, postérieures au 1er janvier 2025, ne figurent pas dans cette édition du Code officiel géographique. Elles seront intégrées au millésime 2026."
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file leximpact_dotations_back-5.1.0-py3-none-any.whl.
File metadata
- Download URL: leximpact_dotations_back-5.1.0-py3-none-any.whl
- Upload date:
- Size: 58.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
11c9287722b3d3257da9ed26934f06e66817f962fbf605934271be021dfb50bc
|
|
| MD5 |
267852c918302215c4a88bc9aa25181c
|
|
| BLAKE2b-256 |
5034e614e39d2cf80a012ece5ca5b73983f86851bb6436d10d19e389201d0f59
|