Python自动化:自动向Word文档中添加数据和图片,智能调整版面
off999 2024-12-03 00:15 24 浏览 0 评论
在繁忙的职场生活中,你是否经常需要手动往Word文档中插入图片,并调整其大小和位置以符合文档格式要求?这样的工作不仅繁琐,而且效率低下,尤其是在制造业,每周的6S稽核后,面对成堆的稽核记录和图片,是不是觉得手动整理这些文档简直是一种折磨?。今天,我们要介绍的是如何利用Python这个强大的自动化工具,一键批量为Word文档添加并调整图片,让你的办公效率瞬间飙升!
痛点分析
在日常的办公中,图片是文档中不可或缺的一部分,但手动添加和调整图片往往耗费大量时间和精力。尤其是当需要添加的图片数量较多时,重复性的操作更是让人苦不堪言。比如:在日常的6S稽核工作中,我们不仅要记录问题、描述情况,还要将现场拍摄的照片添加到Word文档中。然而,直接将图片粘贴到文档中,往往会导致文档排版混乱,图片大小不合适,需要手动调整。这样的重复性工作,不仅耗时耗力,还容易出错。此时,如果能有一种自动化工具来帮助我们完成这些任务,将极大地提高我们的工作效率。
解决方案
有了Python的助力,我们可以轻松实现Word文档的自动化处理。首先,将序号、问题描述和责任部门等信息录入Excel表格,然后利用Python读取这些信息,并自动在Word文档的指定位置添加图片,同时调整图片大小,使其符合排版要求。
实现步骤
- 准备材料:将稽核记录整理成Excel表格,同时收集好对应的图片文件。
- 编写代码:使用Python的python-docx库来操作Word文档,openpyxl库来读取Excel表格数据
- 读取数据:遍历Excel表格,读取每条记录的信息(序号、问题描述、责任部门)和对应的图片路径。
- 添加图片:在Word文档中指定位置添加图片,并调整图片大小,使其适应文档排版,并在指定位置添加问题、时间等信息
- 保存文档:完成所有记录的处理后,保存Word文档。
#提取Excel表中的数据
from openpyxl import load_workbook #用于读取Excel中的信息
wb = load_workbook('数据.xlsx')
ws = wb.active
data=[]
for row in range(2,ws.max_row+1):
number = ws['A' + str(row)].value
problem = ws['B' + str(row)].value
owner = ws['C' + str(row)].value
info_list = [number,problem,owner]
data.append(info_list)
from docx import Document
from docx.shared import Cm
import os
doc = Document("6S稽查问题模板.docx")
#将图片按修改时间排序(这样才能与图片的描述一致),将路径存入列表,以便后面逐个插入图片时调用
path = "6s_pictures"
list_p = [path+"\\"+i for i in os.listdir(path)] #获取图片的文件名,并拼接完整路径
list_p.sort(key=lambda path: os.path.getmtime(path)) #将列表中的文件按其修改时间排序,os.path.getmtime() 函数是获取文件最后修改时间
table = doc.tables[0] #已确定是第一个表格,其索引是0
#增加需要的行,以便足够填入数据
for i in range(len(data)-1):
table.add_row()
#写入数据及图片
for row in range(1,len(data)+1):
table.cell(row,0).text = str(data[row-1][0]) #往第1列写入序号
table.cell(row,1).text = data[row-1][1] #往第2列写入问题描述
table.cell(row,3).text = data[row-1][2] #往第4列写入责任部门
#插入图片并调整图片的高度和宽度,以适合模板中的单元格尺寸
run = table.cell(row,2).paragraphs[0].add_run() #新增一个文字块
picture = run.add_picture(list_p[row-1]) #插入图片
picture.height = Cm(4.4) #设置图片高度
picture.width = Cm(6.2) #设置图片宽度
doc.save("6S稽查问题.docx")效果展示
经过Python的自动化处理,原本混乱的Word文档变得整洁有序,图片大小适中,排版美观。而且,整个过程只需要几分钟时间,大大节省了人力成本和时间成本。
结语
Python作为一种强大的编程语言,不仅可以在数据分析、机器学习等领域大放异彩,还可以在办公自动化方面发挥巨大作用。通过今天的分享,相信大家已经感受到了Python在办公自动化方面的强大魅力。让我们一起拥抱Python,让工作变得更简单、更高效吧!
数海丹心
大数据和人工智能知识分享与应用
108篇原创内容
公众号
相关推荐
- 2025十佳笔记本排行(2021年十大最佳笔记本)
-
2021年,笔记本电脑用什么CPU最好用?当然是艾灸系列最新12代的CPU最好用,也需要根据他的具体配置搭配什么样的主板和显卡,按成熟度来说,还是选择次心大的笔记本CPU比较好,因为硬件搭配也是202...
- 手机谷歌浏览器(手机谷歌浏览器怎么关闭无痕模式)
-
使用手机chrome方法:1、打开手机上的谷歌浏览器2、点击打开后,找到右上角的三个小点,点开它,会看到“设置”3、点开设置,然后会出现“搜索引擎”4、点开“搜索引擎”然后选择“搜狗”。5、然后一步步...
- 千兆网对路由器有要求吗(千兆路由器对无线有用吗)
-
回答:虽然不是必须,但是建议采用千兆路由器。只有使用千兆路由器,才能达到1000M光纤的最高网速。当使用旧的百兆路由器情况下,千兆带宽只能达到百兆网速。不能充分利用带宽,这样对您的千兆互联网光纤带宽...
- win7重装系统方法(win7系统重装详细步骤)
-
步骤1、打开云骑士装机大师,点击一键装机下的【立即重装】,检测完毕后点击【下一步】;步骤2、选择windows7下的旗舰版32位,点击【下一步】,自行选择或取消推荐的软件,点击【下一步】;步骤3、备份...
- 电脑桌面啥都没有了怎么回事
-
1、如果我们桌面上什么东西都没有,可以先打开任务管理器,然后顶级左上方的文件,随后新建任务,在打开的界面中输入explorer,点击确认之后,等个几秒钟左右就可以看见桌面上的图标了。 2、另一个方法...
- 如何将电脑恢复出厂设置win7
-
1.首先我们打开电脑找到“计算机”点击打开。2.进入页面然后我们点击“Windows7(C:)”打开C盘。3.我们在C盘界面找到Windows7并点击打开。4.进入到Win7文件夹中找到并双击“Sys...
- u盘存在但是读不出来(u盘显示有内容但读不出来怎么办)
-
u盘能识别,不能读取可能是你关闭了u盘自动读取,取消后即可。步骤:1、在电脑桌面右键点击“计算机”,在出现的菜单中选择“管理”选项2、在弹出的计算机管理窗口,依次打开“计算机管理-服务和应用程序-服务...
- win8家庭中文版下载(windows家庭中文版下载)
-
可以按照以下步骤在Win8上下载和安装Word:1.通过微软官网下载购买,或者通过MicrosoftStore应用商店进行购买和下载。2.下载完成后,打开文件夹,双击setup进行安装。3.安...
- 教大家强制退出苹果id账号(教大家强制退出苹果id账号ipad)
-
1.首先将手机强制关机,并在电脑端安装iTunes并打开。2.用数据线将手机与电脑连接起来,长按手机电源键。3.当出现苹果标志时不要松开电源键,接着按Home键。4.直到屏幕黑屏,松开电源键。5.继续...
- 惠普官网驱动下载官网(惠普驱动官方)
-
在惠普官网下载系统驱动方法如下访问HP官网:www.hp.com找到支持与驱动页面(通常在顶部导航栏的支持或下载中)输入你的HP产品的序列号或选择产品类型和型号选择你的操作系统,然后下载相关的驱动。安...
- 电脑公司取名字大全(电脑行业公司取名)
-
动感网络IT狂人行鱼雷IT网PC宝宝网外有鱼超导技术网PC技术网加点分吧,不然想不出太多,呵呵绿苑计算机协会绿色代表生命,有起航的意义,苑是一个范畴,有地域的意思,是给你们一片天地的意思...
- wifi怎么设置网速快(手机测wifi网速怎么测)
-
wifi加速设置方法步骤如下。1设置网速:浏览器中输入终端地址,输入账号和密码。找到连接设备数目并进行更改,找到信道宽度,选择更快的网速。2提高WiFi网速:进入设置中心,点击WLAN选项。点击高级设...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
慕ke 前端工程师2024「完整」
-
失业程序员复习python笔记——条件与循环
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
