当前位置: 首页 > news >正文

docxtpl,一个强大的 Python 库!

更多资料获取

📚 个人网站:ipengtao.com


大家好,今天为大家分享一个强大的 Python 库 - docxtpl。

项目地址:https://docxtpl.readthedocs.io/en/latest/


在日常工作中,自动生成和处理 Word 文档是一个常见需求。docxtpl 是一个功能强大的 Python 库,专门用于基于模板生成 Microsoft Word 文档。它使得通过预定义的模板快速生成个性化的文档变得非常简单,适用于生成合同、报告、发票等。本文将详细介绍 docxtpl 库,包括其安装方法、主要特性、基本和高级功能,以及实际应用场景,帮助全面了解并掌握该库的使用。

安装

要使用 docxtpl 库,首先需要安装它。可以通过 pip 工具方便地进行安装。

以下是安装步骤:

pip install docxtpl

安装完成后,可以通过导入 docxtpl 库来验证是否安装成功:

import docxtpl
print("docxtpl 库安装成功!")

特性

  1. 模板驱动:基于预定义的 Word 模板生成文档,简单直观。
  2. 变量替换:支持在模板中使用变量和表达式,自动替换为实际值。
  3. 丰富的控制结构:支持循环、条件判断等控制结构,生成动态内容。
  4. 图片嵌入:支持在文档中嵌入图片,生成图文并茂的文档。
  5. 表格和列表:支持生成复杂的表格和列表,满足各种文档需求。

基本功能

创建简单文档

使用 docxtpl,可以方便地创建一个简单的 Word 文档。

from docxtpl import DocxTemplate# 创建模板文档
doc = DocxTemplate("template.docx")# 定义要替换的变量
context = {'name': 'John Doe','date': '2023-06-01'
}# 渲染模板
doc.render(context)# 保存生成的文档
doc.save("generated_doc.docx")

插入图片

docxtpl 支持在文档中插入图片。

from docxtpl import DocxTemplate, InlineImage
from docx.shared import Cm# 创建模板文档
doc = DocxTemplate("template_with_image.docx")# 定义要替换的变量
context = {'name': 'Jane Doe','image': InlineImage(doc, 'image.png', width=Cm(5))
}# 渲染模板
doc.render(context)# 保存生成的文档
doc.save("generated_doc_with_image.docx")

生成表格

docxtpl 支持生成复杂的表格。

from docxtpl import DocxTemplate# 创建模板文档
doc = DocxTemplate("template_with_table.docx")# 定义要替换的变量
context = {'table_data': [{'item': 'Item 1', 'description': 'Description 1', 'price': 10},{'item': 'Item 2', 'description': 'Description 2', 'price': 20},{'item': 'Item 3', 'description': 'Description 3', 'price': 30}]
}# 渲染模板
doc.render(context)# 保存生成的文档
doc.save("generated_doc_with_table.docx")

高级功能

使用控制结构

docxtpl 支持在模板中使用控制结构,如循环和条件判断。

from docxtpl import DocxTemplate# 创建模板文档
doc = DocxTemplate("template_with_control_structures.docx")# 定义要替换的变量
context = {'items': [{'name': 'Item 1', 'price': 10},{'name': 'Item 2', 'price': 20},{'name': 'Item 3', 'price': 30}],'total_price': 60,'discount': 5
}# 渲染模板
doc.render(context)# 保存生成的文档
doc.save("generated_doc_with_control_structures.docx")

嵌套表格

docxtpl 支持嵌套表格的生成。

from docxtpl import DocxTemplate# 创建模板文档
doc = DocxTemplate("template_with_nested_table.docx")# 定义要替换的变量
context = {'orders': [{'order_id': '1001','items': [{'name': 'Item A', 'quantity': 2, 'price': 100},{'name': 'Item B', 'quantity': 1, 'price': 200}],'total': 400},{'order_id': '1002','items': [{'name': 'Item C', 'quantity': 3, 'price': 50},{'name': 'Item D', 'quantity': 2, 'price': 150}],'total': 450}]
}# 渲染模板
doc.render(context)# 保存生成的文档
doc.save("generated_doc_with_nested_table.docx")

动态图片

docxtpl 支持动态插入图片。

from docxtpl import DocxTemplate, InlineImage
from docx.shared import Cm# 创建模板文档
doc = DocxTemplate("template_with_dynamic_images.docx")# 定义要替换的变量
context = {'products': [{'name': 'Product 1', 'image': InlineImage(doc, 'product1.png', width=Cm(4))},{'name': 'Product 2', 'image': InlineImage(doc, 'product2.png', width=Cm(4))}]
}# 渲染模板
doc.render(context)# 保存生成的文档
doc.save("generated_doc_with_dynamic_images.docx")

实际应用场景

合同生成

通过 docxtpl 自动生成合同文档,减少手动填写的工作量。

from docxtpl import DocxTemplate# 创建模板文档
doc = DocxTemplate("contract_template.docx")# 定义要替换的变量
context = {'party_a': 'Company A','party_b': 'Company B','contract_date': '2023-06-01','contract_terms': 'All terms and conditions of the contract...'
}# 渲染模板
doc.render(context)# 保存生成的合同文档
doc.save("generated_contract.docx")

报告生成

通过 docxtpl 自动生成数据报告,方便定期生成和分发。

from docxtpl import DocxTemplate# 创建模板文档
doc = DocxTemplate("report_template.docx")# 定义要替换的变量
context = {'report_date': '2023-06-01','author': 'John Doe','summary': 'This is a summary of the report...','details': 'Detailed data and analysis...','conclusion': 'Conclusion of the report...'
}# 渲染模板
doc.render(context)# 保存生成的报告文档
doc.save("generated_report.docx")

发票生成

通过 docxtpl 自动生成发票,减少手动填写和计算的工作量。

from docxtpl import DocxTemplate# 创建模板文档
doc = DocxTemplate("invoice_template.docx")# 定义要替换的变量
context = {'invoice_number': 'INV-2023-001','billing_date': '2023-06-01','customer_name': 'Jane Doe','items': [{'description': 'Item 1', 'quantity': 2, 'unit_price': 100, 'total': 200},{'description': 'Item 2', 'quantity': 1, 'unit_price': 150, 'total': 150}],'subtotal': 350,'tax': 35,'total': 385
}# 渲染模板
doc.render(context)# 保存生成的发票文档
doc.save("generated_invoice.docx")

总结

docxtpl 库是一个功能强大且易于使用的文档生成工具,能够帮助开发者在 Python 项目中高效地创建和管理 Word 文档。通过支持基于模板的文档生成、变量替换、丰富的控制结构、图片嵌入和复杂表格生成,docxtpl 能够满足各种复杂的文档生成需求。本文详细介绍了 docxtpl 库的安装方法、主要特性、基本和高级功能,以及实际应用场景。希望本文能帮助大家全面掌握 docxtpl 库的使用,并在实际项目中发挥其优势。


Python学习路线

在这里插入图片描述

更多资料获取

📚 个人网站:ipengtao.com

如果还想要领取更多更丰富的资料,可以点击文章下方名片,回复【优质资料】,即可获取 全方位学习资料包。

在这里插入图片描述
点击文章下方链接卡片,回复【优质资料】,可直接领取资料大礼包。

相关文章:

docxtpl,一个强大的 Python 库!

更多资料获取 📚 个人网站:ipengtao.com 大家好,今天为大家分享一个强大的 Python 库 - docxtpl。 项目地址:https://docxtpl.readthedocs.io/en/latest/ 在日常工作中,自动生成和处理 Word 文档是一个常见需求。doc…...

捷途山海T2:超长续航,节能环保的驾驶新星

在当今的汽车市场中,消费者的购车选择日趋多样化,不再仅限于传统的燃油车。随着环保理念的深入人心以及人们对用车成本的日益关注,像捷途山海T2这样配备高效混动系统的车型逐渐受到大众的青睐。 捷途山海T2,以其杰出的节能性、强劲…...

[Day 45] 區塊鏈與人工智能的聯動應用:理論、技術與實踐

區塊鏈的可擴展性挑戰 概述 區塊鏈技術在過去幾年中取得了顯著的進展,其去中心化、透明和安全的特性使其在金融、供應鏈管理、醫療等領域得到了廣泛應用。然而,區塊鏈技術的一個重大挑戰是其可擴展性。可擴展性是指系統能夠有效處理日益增長的數據和用…...

白骑士的PyCharm教学实战项目篇 4.3 自动化测试与持续集成

系列目录 上一篇: 在现代软件开发过程中,自动化测试与持续集成(CI)是确保代码质量和快速交付的关键环节。PyCharm作为一款强大的集成开发环境(IDE),为自动化测试和持续集成提供了全面的支持。本…...

权限模块开发+权限与角色关联(完整CRUD)

文章目录 🌞 Sun Frame:SpringBoot 的轻量级开发框架(个人开源项目推荐)🌟 亮点功能📦 spring cloud模块概览常用工具 🔗 更多信息1.easycode生成代码1.配置2.AuthPermissionDao.java剪切到mapp…...

llama神经网络的结构,llama-3-8b.layers=32 llama-3-70b.layers=80; 2000汉字举例说明

目录 llama-3-8b.layers=32 llama-3-70b.layers=80 llama神经网络的结构 Llama神经网络结构示例 示例中的输入输出大小 实际举例说明2000个汉字文本数据集 初始化词嵌入矩阵 1. 输入层 2. 嵌入层 3. 卷积层 4. 全连接层 llama-3-8b.layers=32 llama-3-70b.laye…...

单细胞数据怎么表现genes mRNA表达的热图?

愿武艺晴小朋友一定得每天都开心 #热图 library("ComplexHeatmap") exp <- AverageExpression(subset(fasting_memory, Celltype %in% c("Pre-B")), layer = "data", #即CPM值 features …...

Java聚合快递对接云洋系统小程序源码

&#x1f680;【物流新纪元】聚合快递如何无缝对接云洋系统&#xff0c;效率飙升秘籍大公开&#xff01;✨ &#x1f50d; 开篇揭秘&#xff1a;聚合快递的魅力所在 Hey小伙伴们&#xff0c;你是否还在为多家快递公司账号管理繁琐、订单处理效率低下而头疼&#xff1f;&#…...

MySQL——数据表的基本操作(三)修改数据表

有时候&#xff0c;希望对表中的某些信息进行修改&#xff0c;这时就需要修改数据表。所谓修改数据表指的是修改数据库中已经存在的数据表结构&#xff0c;比如&#xff0c;修改表名、修改字段名、修改字段的数据类型等。在 MySQL中&#xff0c;修改数据表的操作都是使用 ALTER…...

医学图像分割的基准:TransUnet(用于医学图像分割的Transformer编码器)器官分割

1、 TransUnet 介绍 TransUnet是一种用于医学图像分割的深度学习模型。它是基于Transformer模型的图像分割方法&#xff0c;由AI研究公司Hugging Face在2021年提出。 医学图像分割是一项重要的任务&#xff0c;旨在将医学图像中的不同结构和区域分离出来&#xff0c;以便医生可…...

java-swing编写学生成绩查询管理系统

本文是本人大二上实训项目-学生成绩查询管理系统&#xff0c;采用本项目使用Java、MySQL技术。界面框架由Java Swing搭建&#xff0c;用JDBC实现Java与MySQL的连接。 本项目适合初学java和mysql的同学&#xff0c;来做一些小项目来提升自己&#xff0c;因为兴趣所以想要做去尝…...

volatile浅解

volatile修饰的变量有两个特点 线程中修改了自己工作内存中的副本后&#xff0c;立即将其刷新到主内存工作内存中每次读取共享变量时&#xff0c;都会去主内存中重新读取&#xff0c;然后拷贝到工作内存 内存 -> CPU Cache -> CPU 如果没有volatile那么就会继续读取缓存…...

世媒讯带您了解什么是媒体邀约

什么是媒体邀约&#xff1f;其实媒体邀约是一种公关策略&#xff0c;旨在通过邀请媒体记者和编辑参加特定的活动、发布会或其他重要事件&#xff0c;以确保这些活动能够得到广泛的报道和关注。通过这种方式&#xff0c;企业和组织希望能够传达重要信息&#xff0c;提高品牌知名…...

[Kimi 笔记]“面向搜索引擎”

"面向搜索引擎"&#xff08;Search Engine-Oriented&#xff0c;SEO-Oriented 或 SEO-Friendly&#xff09;通常指的是在设计和开发网站时&#xff0c;采取一系列措施来优化网站内容和结构&#xff0c;以便提高网站在搜索引擎结果页面&#xff08;SERP&#xff09;中…...

如何在亚马逊云科技AWS上利用LoRA高效微调AI大模型减少预测偏差

简介&#xff1a; 小李哥将继续每天介绍一个基于亚马逊云科技AWS云计算平台的全球前沿AI技术解决方案&#xff0c;帮助大家快速了解国际上最热门的云计算平台亚马逊云科技AWS AI最佳实践&#xff0c;并应用到自己的日常工作里。 在机器学习和人工智能领域&#xff0c;生成偏差…...

订单定时状态处理业务(SpringTask)

文章目录 概要整体架构流程技术细节小结 概要 订单定时状态处理通常涉及到对订单状态进行定期检查&#xff0c;并根据订单的状态自动执行某些操作&#xff0c;比如关闭未支付的订单、自动确认收货等. 需求分析以及接口设计 需求分析 用户下单后可能存在的情况&#xff1a; …...

STM32 | ADC+RS485(第十天)

点击上方"蓝字"关注我们 01、ADC概述 ADC, Analog-to-Digital Converter的缩写,指模/数转换器或者模拟/数字转换器。是指将连续变量的模拟信号转换为离散的数字信号的器件。真实世界的模拟信号.例如温度、压力、声音或者图像等,需要转换成更容易储存、处理和发射的…...

python打包成能够在mac里面运行的程序

要将你的PyQt5应用程序打包成可以在macOS上运行的独立应用程序&#xff0c;可以使用工具如PyInstaller或py2app。下面是使用py2app的详细步骤&#xff0c;因为它是macOS上专用的打包工具&#xff0c;并且更好地支持PyQt5。 1. 安装py2app 首先&#xff0c;确保你的macOS系统上…...

基于FPGA的数字信号处理(20)--半减器和全减器

目录 1、前言 2、半减器 3、全减器 4、减法器 文章总目录点这里&#xff1a;《基于FPGA的数字信号处理》专栏的导航与说明 1、前言 既然有半加器和全加器&#xff0c;那自然也有半减器和全减器了。尽管在电路中减法的实现基本都是 补码 加法 的形式&#xff0c;但是正所谓…...

Python:单引号,双引号,三引号的区别

在Python中&#xff0c;单引号&#xff08;&#xff09;、双引号&#xff08;"&#xff09;和三引号&#xff08; 或 """&#xff09;都可以用来定义字符串&#xff0c;但它们之间有一些区别&#xff1a; 单引号&#xff08;&#xff09;和双引号&#xf…...

深入浅出Asp.Net Core MVC应用开发系列-AspNetCore中的日志记录

ASP.NET Core 是一个跨平台的开源框架&#xff0c;用于在 Windows、macOS 或 Linux 上生成基于云的新式 Web 应用。 ASP.NET Core 中的日志记录 .NET 通过 ILogger API 支持高性能结构化日志记录&#xff0c;以帮助监视应用程序行为和诊断问题。 可以通过配置不同的记录提供程…...

脑机新手指南(八):OpenBCI_GUI:从环境搭建到数据可视化(下)

一、数据处理与分析实战 &#xff08;一&#xff09;实时滤波与参数调整 基础滤波操作 60Hz 工频滤波&#xff1a;勾选界面右侧 “60Hz” 复选框&#xff0c;可有效抑制电网干扰&#xff08;适用于北美地区&#xff0c;欧洲用户可调整为 50Hz&#xff09;。 平滑处理&…...

FastAPI 教程:从入门到实践

FastAPI 是一个现代、快速&#xff08;高性能&#xff09;的 Web 框架&#xff0c;用于构建 API&#xff0c;支持 Python 3.6。它基于标准 Python 类型提示&#xff0c;易于学习且功能强大。以下是一个完整的 FastAPI 入门教程&#xff0c;涵盖从环境搭建到创建并运行一个简单的…...

dedecms 织梦自定义表单留言增加ajax验证码功能

增加ajax功能模块&#xff0c;用户不点击提交按钮&#xff0c;只要输入框失去焦点&#xff0c;就会提前提示验证码是否正确。 一&#xff0c;模板上增加验证码 <input name"vdcode"id"vdcode" placeholder"请输入验证码" type"text&quo…...

【快手拥抱开源】通过快手团队开源的 KwaiCoder-AutoThink-preview 解锁大语言模型的潜力

引言&#xff1a; 在人工智能快速发展的浪潮中&#xff0c;快手Kwaipilot团队推出的 KwaiCoder-AutoThink-preview 具有里程碑意义——这是首个公开的AutoThink大语言模型&#xff08;LLM&#xff09;。该模型代表着该领域的重大突破&#xff0c;通过独特方式融合思考与非思考…...

WEB3全栈开发——面试专业技能点P2智能合约开发(Solidity)

一、Solidity合约开发 下面是 Solidity 合约开发 的概念、代码示例及讲解&#xff0c;适合用作学习或写简历项目背景说明。 &#x1f9e0; 一、概念简介&#xff1a;Solidity 合约开发 Solidity 是一种专门为 以太坊&#xff08;Ethereum&#xff09;平台编写智能合约的高级编…...

Spring数据访问模块设计

前面我们已经完成了IoC和web模块的设计&#xff0c;聪明的码友立马就知道了&#xff0c;该到数据访问模块了&#xff0c;要不就这俩玩个6啊&#xff0c;查库势在必行&#xff0c;至此&#xff0c;它来了。 一、核心设计理念 1、痛点在哪 应用离不开数据&#xff08;数据库、No…...

微软PowerBI考试 PL300-在 Power BI 中清理、转换和加载数据

微软PowerBI考试 PL300-在 Power BI 中清理、转换和加载数据 Power Query 具有大量专门帮助您清理和准备数据以供分析的功能。 您将了解如何简化复杂模型、更改数据类型、重命名对象和透视数据。 您还将了解如何分析列&#xff0c;以便知晓哪些列包含有价值的数据&#xff0c;…...

Android第十三次面试总结(四大 组件基础)

Activity生命周期和四大启动模式详解 一、Activity 生命周期 Activity 的生命周期由一系列回调方法组成&#xff0c;用于管理其创建、可见性、焦点和销毁过程。以下是核心方法及其调用时机&#xff1a; ​onCreate()​​ ​调用时机​&#xff1a;Activity 首次创建时调用。​…...

让回归模型不再被异常值“带跑偏“,MSE和Cauchy损失函数在噪声数据环境下的实战对比

在机器学习的回归分析中&#xff0c;损失函数的选择对模型性能具有决定性影响。均方误差&#xff08;MSE&#xff09;作为经典的损失函数&#xff0c;在处理干净数据时表现优异&#xff0c;但在面对包含异常值的噪声数据时&#xff0c;其对大误差的二次惩罚机制往往导致模型参数…...