当前位置: 首页 > 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…...

Linux 文件类型,目录与路径,文件与目录管理

文件类型 后面的字符表示文件类型标志 普通文件&#xff1a;-&#xff08;纯文本文件&#xff0c;二进制文件&#xff0c;数据格式文件&#xff09; 如文本文件、图片、程序文件等。 目录文件&#xff1a;d&#xff08;directory&#xff09; 用来存放其他文件或子目录。 设备…...

理解 MCP 工作流:使用 Ollama 和 LangChain 构建本地 MCP 客户端

&#x1f31f; 什么是 MCP&#xff1f; 模型控制协议 (MCP) 是一种创新的协议&#xff0c;旨在无缝连接 AI 模型与应用程序。 MCP 是一个开源协议&#xff0c;它标准化了我们的 LLM 应用程序连接所需工具和数据源并与之协作的方式。 可以把它想象成你的 AI 模型 和想要使用它…...

高频面试之3Zookeeper

高频面试之3Zookeeper 文章目录 高频面试之3Zookeeper3.1 常用命令3.2 选举机制3.3 Zookeeper符合法则中哪两个&#xff1f;3.4 Zookeeper脑裂3.5 Zookeeper用来干嘛了 3.1 常用命令 ls、get、create、delete、deleteall3.2 选举机制 半数机制&#xff08;过半机制&#xff0…...

鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个医院查看报告小程序

一、开发环境准备 ​​工具安装​​&#xff1a; 下载安装DevEco Studio 4.0&#xff08;支持HarmonyOS 5&#xff09;配置HarmonyOS SDK 5.0确保Node.js版本≥14 ​​项目初始化​​&#xff1a; ohpm init harmony/hospital-report-app 二、核心功能模块实现 1. 报告列表…...

uniapp微信小程序视频实时流+pc端预览方案

方案类型技术实现是否免费优点缺点适用场景延迟范围开发复杂度​WebSocket图片帧​定时拍照Base64传输✅ 完全免费无需服务器 纯前端实现高延迟高流量 帧率极低个人demo测试 超低频监控500ms-2s⭐⭐​RTMP推流​TRTC/即构SDK推流❌ 付费方案 &#xff08;部分有免费额度&#x…...

Java入门学习详细版(一)

大家好&#xff0c;Java 学习是一个系统学习的过程&#xff0c;核心原则就是“理论 实践 坚持”&#xff0c;并且需循序渐进&#xff0c;不可过于着急&#xff0c;本篇文章推出的这份详细入门学习资料将带大家从零基础开始&#xff0c;逐步掌握 Java 的核心概念和编程技能。 …...

Reasoning over Uncertain Text by Generative Large Language Models

https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829 1. 概述 文本中的不确定性在许多语境中传达,从日常对话到特定领域的文档(例如医学文档)(Heritage 2013;Landmark、Gulbrandsen 和 Svenevei…...

return this;返回的是谁

一个审批系统的示例来演示责任链模式的实现。假设公司需要处理不同金额的采购申请&#xff0c;不同级别的经理有不同的审批权限&#xff1a; // 抽象处理者&#xff1a;审批者 abstract class Approver {protected Approver successor; // 下一个处理者// 设置下一个处理者pub…...

Linux 中如何提取压缩文件 ?

Linux 是一种流行的开源操作系统&#xff0c;它提供了许多工具来管理、压缩和解压缩文件。压缩文件有助于节省存储空间&#xff0c;使数据传输更快。本指南将向您展示如何在 Linux 中提取不同类型的压缩文件。 1. Unpacking ZIP Files ZIP 文件是非常常见的&#xff0c;要在 …...

【Linux】自动化构建-Make/Makefile

前言 上文我们讲到了Linux中的编译器gcc/g 【Linux】编译器gcc/g及其库的详细介绍-CSDN博客 本来我们将一个对于编译来说很重要的工具&#xff1a;make/makfile 1.背景 在一个工程中源文件不计其数&#xff0c;其按类型、功能、模块分别放在若干个目录中&#xff0c;mak…...