【Python】python使用docxtpl生成word模板

python使用docxtpl生成word模板

python-docxtpl包简单使用和实战,Python处理word,docx文件。
最近需要处理一些爬虫得到的数据来进行一些自动化报告的操作,因为需要生成的是word的报告,所以估选用docxtpl库来直接生成模板

docxtpl 模板标签主要来自jinja2,可以了解 jinja2语法,也有些额外的不一样,可以自行百度或者参考官方文档

开始

使用Pip安装docxtpl

pip install docxtpl
简单demo
根据官网的简单举例:

from docxtpl import DocxTemplate
doc = DocxTemplate(“my_word_template.docx”) # 读取模板
context = { ‘company_name’ : “World company” } # 需要传入的字典, 需要在word对应的位置输入 {{ company_name }}
doc.render(context) # 渲染到模板中
doc.save(“generated_doc.docx”) # 生成一个新的模板
至此,就可以直接拿来实战了, 实战中包含了图片的替换和表格文本的一些插入。都是很简单的,就是将组成的字典渲染到word中去就可以

实战

#!/usr/bin/env python

-- encoding: utf-8 --

‘’’
@File : generate_word.py
@Time : 2021/05/28 15:52:57
@Author : OD
@Version : 1.0
‘’’

here put the import lib

from docx import Document
from docx.shared import Pt
import datetime
from docxtpl import DocxTemplate, RichText, InlineImage
from docx.shared import Mm
import json

根据模板生成一个周报内容

class Generate2Word:
def init(self):
self.now = str(datetime.date.today() - datetime.timedelta(days=0)).replace(“-”, “”).replace(" “, “”)
self.last = str(datetime.date.today() - datetime.timedelta(days=7)).replace(”-“, “”).replace(” “, “”)
self.now = self.now[4:6] + ‘.’ + self.now[6:] # 现在时间
self.last = self.last[4:6] + ‘.’ + self.last[6:] # 7天前时间
def generate_report(self, tpl_file, report_file):
tpl= DocxTemplate(tpl_file)
# 第一个图表
context = {
‘start_time’ : self.last,
‘end_time’ : self.now,
‘total_attention’: 123,
‘add_attention’: 20,
‘dau’: 100,
‘dau_per’:20 / 100,
‘theme_tiezi’:1234,
‘all_tiezi’: 12345,
‘add_theme_tiezi’: 25,
‘add_tiezi’: 20,
‘official_pub’:12,
‘del_tiezi’: 5,
}
image1_path = r’1.png’ # 要生成的图片地址
image2_path = r’2.png’ # 要生成的图片地址
insert_image1 = InlineImage(tpl, image1_path, width=Mm(140))
insert_image2 = InlineImage(tpl, image2_path, width=Mm(140))
# 作为图片的替换
img_context = {
‘img1’: insert_image1,
‘img2’: insert_image2
}
# 管理帖子,需要渲染
bawu_lists = {
“bawu_table”:
[{
‘publish_time’: ‘2021/5/7’,
‘title’: ‘测试1’,
‘link’: 'https://www.baidu,com,
‘reply_num’: 27
},
{
‘publish_time’: ‘2021/5/8’,
‘title’: ‘测试2’,
‘link’: ‘https://www.baidu,com’,
‘reply_num’: 4
},
{
‘publish_time’: ‘2021/5/31’,
‘title’: ‘湖人浓眉伤退’,
‘link’: ‘https://www.baidu,com’,
‘reply_num’: 40
},
{
‘publish_time’: ‘2021/6/2’,
‘title’: ‘勒布朗詹姆斯率队拿下g5’,
‘link’: ‘https://www.baidu,com’,
‘reply_num’: 444
}
],
“navy_table”:
[{
‘publish_time’: ‘2021/4/23’,
‘title’: ‘测试3’,
‘link’: ‘https://www.baidu,com’,
‘reply_num’: 444
},
{
‘publish_time’: ‘2021/4/30’,
‘title’: ‘测试4’,
‘link’: ‘https://www.baidu,com’,
‘reply_num’: 444
},
{
‘publish_time’: ‘2021/5/30’,
‘title’: ‘测试5’,
‘link’: ‘https://www.baidu,com’,
‘reply_num’: 444
}
]
}
bawu_summary = dict()
bawu_sum_reply = 0 # 总有多少个回复
for bawu_data in bawu_lists.get(‘bawu_table’):
bawu_summary[‘bawu_publish_num’] = len(bawu_lists.get(‘bawu_table’, 0))
bawu_sum_reply += int(bawu_data.get(‘reply_num’, 0))
bawu_summary[‘bawu_sum_reply’] = bawu_sum_reply
navy_summary = dict()
navy_sum_reply = 0
for navy_data in bawu_lists.get(‘navy_table’):
navy_summary[‘navy_publish_num’] = len(bawu_lists.get(‘navy_table’, 0))
navy_sum_reply += int(navy_data.get(‘reply_num’, 0))
navy_summary[‘navy_sum_reply’] = navy_sum_reply
tpl.render({**context, **img_context, ** bawu_lists, **bawu_summary, **navy_summary}) # 多个字典解构
print(‘生成模板成功…’)
tpl.save(report_file)
def main(self):
tpl_file = “文件模板.docx” # 指定的模板
report_file = f"新得{self.last}-{self.now}报告.docx” # 指定生成的报告位置
self.generate_report(tpl_file, report_file)
if name == ‘main’:
demo = Generate2Word()
demo.main()
这样 就可以生成一个保留 word 格式的一个报告。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/62334.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端需要理解的数据治理与异常监控知识

服务监控包括错误监控、性能监控和行为监控。数据埋点是对服务监控中收集用户信息的技术实现,分为侵入式和非侵入式。 1 数据治理 前端数据治理的重要指标是准确性和数据,一个数据对象包括数据值和其他元数据。 2 数据上报方式 2.1 Image 通过将采集…

nodejs发布静态https服务器

1、先用 npm init 创建一个package.json,然后添加依赖 node-static ,package.json 如下: {"name": "freeswitch","version": "1.0.0","description": "test freeswitch for webrtc&…

20种数据相似性计算方法

不同的相似性计算方法适用于不同类型的数据和问题。在选择相似性计算方法时,需根据数据的特性、问题的定义以及所关注的数据特点来做出合适的选择。 本文归纳了20种数据相似性计算方法以及它们的特点和适用场景,并给出了参考python实现。 相似性计算方法…

windows10默认浏览器总是自动更改为Edge浏览器

在设置的默认应用设置中把默认浏览器改为chrome或其他之后他自动又会改回Edge。不得不说*软真的狗。 解决办法: 后来发现在Edge浏览器的设置中有这么一个选项,会很无耻的默认是Edge。把它关掉后重新设置就行了。

NPM 常用命令(一)

目录 1、npm 1.1 简介 1.2 依赖性 1.3 安装方式 2、npm access 2.1 命令描述 2.2 详情 3、npm adduser 3.1 描述 4、npm audit 4.1 简介 4.2 审计签名 4.3 操作示例 4.4 配置 audit-level dry-run force json package-lock-only omit foreground-scripts …

软考-中级-软件设计师之路

前言:两个月时间复习软考基本知识,下面做知识总结。 1. 计算机概论 第1章主要介绍计算机系统基础知识、计算机体系结构以及安全性、可靠性和系统性能评测基础。 2. 程序设计语言基础知识 第2章主要介绍程序设计语言的基本概念与基本成分,…

从项目中突显技能:在面试中讲述你的编程故事

🌷🍁 博主猫头虎 带您 Go to New World.✨🍁 🦄 博客首页——猫头虎的博客🎐 🐳《面试题大全专栏》 文章图文并茂🦕生动形象🦖简单易学!欢迎大家来踩踩~🌺 &a…

mongodb建用户

玛德折腾了2个小时,、mongodb 建用户。艹 [rootk8-master mongodb]# cat docker-compose.yaml version: 2 services: mongodb: container_name: mongodb_2.0 image: mongo:4.4 restart: always environment: TZ: Asia/Shanghai MONGO_INITDB_ROOT_USERNAME: admin M…

【飞书ChatGPT机器人】飞书接入ChatGPT,打造智能问答助手

文章目录 前言环境列表1.飞书设置2.克隆feishu-chatgpt项目3.配置config.yaml文件4.运行feishu-chatgpt项目5.安装cpolar内网穿透6.固定公网地址7.机器人权限配置8.创建版本9.创建测试企业10. 机器人测试 前言 在飞书中创建chatGPT机器人并且对话,在下面操作步骤中…

reduxreact-redux

redux redux组成部分:state,action,reducer,store store主要职责: 维持应用的state 提供getState()方法获取state 提供dispatch()方法发送action 通过subscribe()来注册监听 通过subscribe()返回值来注销监听 用法: action:必须要有return返…

TDengine函数大全-字符串函数

以下内容来自 TDengine 官方文档 及 GitHub 内容 。 以下所有示例基于 TDengine 3.1.0.3 TDengine函数大全 1.数学函数 2.字符串函数 3.转换函数 4.时间和日期函数 5.聚合函数 6.选择函数 7.时序数据库特有函数 8.系统函数 字符串函数 TDengine函数大全CHAR_LENGTHCONCATCONCA…

结构体的简单介绍

目录 概念: 与数组类比: 结构体声明: 注意: 结构体变量、全局变量、局部变量: 结构体声明中包含其他结构体变量: 结构体变量的初始化: 包含了其他结构体变量的初始化: 结构体…

SPI2外设驱动-W25Q64 SPI接口初始化

前言 (1)本系列是基于STM32的项目笔记,内容涵盖了STM32各种外设的使用,由浅入深。 (2)小编使用的单片机是STM32F105RCT6,项目笔记基于小编的实际项目,但是博客中的内容适用于各种单片…

carbondata优化小姐

一,carbondata高效原因 carbondata文件是hdfs的列式存储格式 查询速度是spark SQL的10倍,通过多种索引技术和多次push down优化,对TB级别数据快速响应 高效的压缩,使用轻量级和和重量级压缩组合的方式,减少60~80%的空间…

【FlowDroid】一、处理流程学习

FlowDroid 一、处理流程学习 下载配置源码概况代码逻辑分析analyzeAPKFilerunInfoflowprocessEntryPointcalculateCallbacks(sourcesAndSinks)再次回到processEntryPoint 自己做一些笔记 下载配置 参照我前面的文章可以使用FlowDroid安装初体验 为了看代码了解FlowDroid如何处…

homeassistant ubuntu自启动 网络设置

命令行安装virtualbox 或者安装包 hass官网下载 haos_ova-10.4.vdi virtualbox 装hass 最少2G内存 其他省略 自启动: gnome-session-properties 添加 VBoxManage startvm hass --type headless hass为自己的虚拟机名字 网络配置如下: 要全部打开

【云原生】Kubernetes容器编排工具

目录 1. K8S介绍 1.1 k8s的由来 下载地址 1.2 docker编排与k8s编排相比 1.3 传统后端部署与k8s 的对比 传统部署 k8s部署 ​2. k8s的集群架构与组件 (1) Kube-apiserver (2)Kube-controller-manager (3&a…

微信小程序开发教学系列(9)- 小程序页面优化

第9章 小程序页面优化 在开发小程序时,页面性能优化是非常重要的一项任务。优化页面性能可以提升用户体验,使小程序更加流畅和高效。本章将介绍一些常见的页面优化方法和技巧,帮助您提升小程序的性能。 9.1 页面性能优化的基本原则 页面性…

vue实现按需加载的多种方式

1.import动态导入 const Home () > import( /* webpackChunkName: "Home" */ /views/Home.vue); 2.使用vue异步组件resolve 这种方式没有成功 //const 组件名 resolve > require([‘组件路径’],resolve) //(这种情况下一个组件生成一个js文件…

vue+elementui前端rules校验缓存问题

场景: 最近公司要求项目前端不要用element-ui,改为使用公司其他组开发的ui组件。 这个ui组件使用基本就是安装后,直接全局替换elementui的el-前缀为公司开发的xx-前缀。 替换之后,发现替换倒是很丝滑,问题不大。可以运…