Maison > développement back-end > Tutoriel Python > Automatisation de la création de documents Word avec Python et FastAPI (à l'aide de python-docx-template)

Automatisation de la création de documents Word avec Python et FastAPI (à l'aide de python-docx-template)

Susan Sarandon
Libérer: 2025-01-08 07:13:41
original
911 Les gens l'ont consulté

Automating Word Document Creation with Python and FastAPI (Using python-docx-template)

Besoin de créer des documents Word avec un contenu dynamique et d'automatiser le processus ? Python, avec la bibliothèque python-docx-template, propose une solution efficace. Ce didacticiel montre comment générer dynamiquement des documents Word, éliminant ainsi le besoin de mises à jour manuelles.

Illustrons avec un exemple de facture. La mise à jour manuelle des données de facturation est fastidieuse et peu pratique lorsqu'il s'agit de données provenant d'API. La génération dynamique résout ce problème.

Envisagez un modèle de document Word :

Automating Word Document Creation with Python and FastAPI (Using python-docx-template)

Les détails de l'entreprise et les listes d'articles changent fréquemment. La génération dynamique gère cette variabilité.

Pour y parvenir, modifiez le modèle pour la compatibilité Jinja2. Les fonctionnalités de création de modèles de Jinja2 (rendu conditionnel, bouclage) permettent un remplissage dynamique basé sur les données fournies.

Le modèle compatible Jinja2 ressemble à ceci :

Automating Word Document Creation with Python and FastAPI (Using python-docx-template)

La syntaxe

Jinja2 (par exemple, {% if %} et {% for %}) peut sembler complexe au départ, mais elle offre un contrôle puissant. Les expressions entre {{ }} représentent des variables renseignées au moment de l'exécution. Par exemple, {% if items %} vérifie si la variable items existe avant de restituer les lignes du tableau. {% for item in items %} parcourt la liste items, générant une ligne pour chaque élément.

Maintenant, créons un serveur FastAPI pour afficher le modèle à l'aide de Python.

  1. Créez un environnement virtuel :

    <code class="language-bash">pip3 install virtualenv
    virtualenv -p python3 venv
    source venv/bin/activate</code>
    Copier après la connexion
    Copier après la connexion
  2. Installer les bibliothèques :

    <code class="language-bash">pip install "fastapi[standard]" docx docxtpl pydantic requests</code>
    Copier après la connexion
  3. Créer main.py : Commencez avec un point de terminaison FastAPI de base :

    <code class="language-python">from fastapi import FastAPI
    app = FastAPI()
    @app.get("/")
    def read_root():
        return {"Hello": "World"}</code>
    Copier après la connexion

    L'accès à localhost:8000 devrait renvoyer {"Hello": "World"}.

  4. Importez le modèle Jinja2 : Placez votre invoice_tpl.docx modifié à la racine du projet.

  5. Améliorer main.py : Le code suivant gère le rendu du modèle, la récupération des images et le calcul du montant total :

    <code class="language-bash">pip3 install virtualenv
    virtualenv -p python3 venv
    source venv/bin/activate</code>
    Copier après la connexion
    Copier après la connexion
  6. Testez le point de terminaison : Envoyez une charge utile JSON (similaire à l'exemple dans le texte original) au / point de terminaison.

  7. Exemples de sortie : (Les images du texte original seraient incluses ici)

Conclusion : Ce didacticiel illustre la génération dynamique de documents Word à l'aide de python-docx-template et FastAPI. La combinaison de Jinja2 et FastAPI crée un système flexible pour automatiser la création de documents. Un prochain article de blog (Partie 2) couvrira la génération de PDF.

Dépôt : https://www.php.cn/link/1df146af0948a68b1342ce39907668fe

Suivez Husein Kantarci :

N'oubliez pas de remplacer les URL des images d'espace réservé par les URL des images réelles. Le code suppose également que vous avez défini les modèles de données nécessaires (Company, BankInformation, Item, VatInformation, InvoiceContext) comme dans l'exemple d'origine.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal