百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

Python自动化:Word文档表格批量处理,几秒钟搞定4000分钟工作

csdh11 2024-12-13 12:18 30 浏览

摘要: 你是否曾在处理Word文档中的表格时,因为上下行相同内容的单元格而感到烦恼?手动合并单元格不仅费时费力,而且容易出错。本文将介绍如何使用Python自动化技术,智能合并Word表格中上下行相同内容的单元格,让你的文档格式更加规范和专业。


Word表格合并单元格的痛点

在职场中,我们经常需要处理大量的Word文档,尤其是包含表格的文档。公众号的一名粉丝,在阅读了我们关于Excel合并单元格《Python自动化:告别手动操作!效率提升上万倍,一键搞定批量Excel单元格的合并与拆分》的文章后,遇到了Word表格合并单元格的需求。作为总经办秘书,他需要将各部门汇总的文档整理成格式统一、美观的报告,以供领导审阅,每次需要合并的word文档有几十上百份,每次手动合并这些文档需要花费几天的时间,手动合并单元格的过程繁琐且容易出错,迫切需要一种自动化的解决方案。

Python自动化合并单元格

问题背景

在Word中,合并单元格与Excel有所不同。Word合并单元格后,会保留所有单元格的值,导致内容重复。我们需要一种方法,智能地识别并合并上下行相同内容的单元格,同时只保留一个值。

核心代码

from docx import Document




def Merge_cells(table, target_list, start_row, col):
    '''
    table: 是需要操作的表格
    target_list: 是目标列表,即含有重复数据的列表
    start_row: 是开始行,即表格中开始比对数据的行(需要将标题除开)
    col: 是需要处理数据的列
    '''
    start = 0  # 开始行计数
    end = 0  # 结束行计数
    reference = target_list[0]  # 设定基准,以列表中的第一个字符串开始
    for i in range(len(target_list)):  # 遍历列表
        if target_list[i] != reference:  # 开始比对,如果内容不同执行如下
            reference = target_list[i]  # 基准变成列表中下一个字符串
            end = i - 1
            table.cell(start+start_row,
                       col).merge(table.cell(end+start_row, col))
            start = end + 1
        if i == len(target_list) - 1:  # 遍历到最后一行,按如下操作
            end = i
            table.cell(start+start_row,
                       col).merge(table.cell(end+start_row, col))




doc = Document("收货记录.docx")
# 读取word文档中的第一个表格的第二和第三列除标题和尾部总数行的数据
table = doc.tables[0]  # 已确定是第一个表格,其索引是0
supplier = []  # 存储供应商名称
pn = []  # 存储物料编码
max_row = len(table.rows)  # 获取第最大一行


# 读取第二行到29行,第2,3列中的数据
for i in range(1, max_row-1):
    supplier_name = table.rows[i].cells[1].text  # cells[1]指表格第二列
    supplier.append(supplier_name)


for i in range(1, max_row-1):
    material_pn = table.rows[i].cells[2].text  # cells[2]指表格第三列
    pn.append(material_pn)


Merge_cells(table, supplier, 1, 1)  # 开始合并行为2,索引为1;供应商名称是在2列,索引为1
Merge_cells(table, pn, 1, 2)  # 开始合并行为2,索引为1;物料编码是在3列,索引为2


# 重新往第2和第3列写入数据,以覆盖之前重复的数据
for row in range(1, len(supplier)+1):
    table.cell(row, 1).text = supplier[row-2]
    table.cell(row, 2).text = pn[row-2]
doc.save("收货记录-合并单元格3.docx")


核心优势

  • 自动化处理:一键处理整个文档中的所有表格。
  • 智能识别:只合并上下行内容相同的单元格。
  • 格式规范:确保文档的格式统一和专业。
  • 效率提升:几秒钟搞定手动工作几天的工作量

结果展示

通过Python脚本,粉丝成功地将所有Word文档中的表格进行了智能合并,大大提升了工作效率和文档的专业性。

结语:自动化,让办公更高效

Python自动化技术在Word文档处理中的应用,不仅提升了工作效率,也让我们有更多的时间专注于内容的创造和分析。让我们拥抱自动化,用技术简化工作,提升办公效率。


你在文档处理中遇到过哪些挑战?在评论区留言,分享你的经验,让我们一起探讨如何用技术提升办公效率!

数海丹心

大数据和人工智能知识分享与应用

127篇原创内容

公众号

相关推荐

IDEA界面太丑??尝试一下这几个插件

前言IntelliJIDEA主要用于支持Java、Scala、Groovy等语言的开发工具,同时具备支持目前主流的技术和框架,擅长于企业应用、移动应用和Web应用的开发。IntelliJi...

小巧 Vue 页面滚动进度条组件ScrollProgress

今天给大家分享一个轻量级Vue.js全屏滚动进度条组件VueScrollProgress。vue-scroll-progress一款基于vue.js构建的页面滚动进度条组件,...

基于vue实现可视化拖拽编辑器,页面生成工具,提升前端开发效率

项目介绍基于vue实现的可视化拖拽编辑器,实现页面生成工具,提升前端开发效率。可以基层到移动端项目作为自定义json直接生成UI页面。项目特点功能特点...

优秀 vue+heyui 后端管理系统HeyUI-Admin

今天再给小伙伴们推荐一款成熟的企业中后台管理系统HEYUI-Admin。heyui-admin基于vue.js和heyui组件库构建的后台管理系统。包含基础表单/表格功能,拓展组件(图表、富文本编辑...

响应式 Vue.js 前端组件化框架Xvue-UI

今天给小伙伴们推荐一款超不错的Vue轻量级组件框架XVueUI。xvue-ui基于vue2.x构建的响应式前端组件化框架。轻量级、易于上手,提供...

《基于SpringBoot+Vue的在线视频系统设计与实现》开题报告

【计算机毕业设计案例】基于SpringBoot+Vue的在线视频系统设计与实现_哔哩哔哩_bilibili...

超好用 Vue.js 图片裁切组件Vue-ImgCutter

今天给小伙伴们分享一个超棒的Vue图片任意裁剪插件VueImgCutter。vue-img-cutter基于vue2.x构建的轻量级剪切图片组件。支持移动图像、放大缩小图片、任意移动图片、固定比...

Vue 3 进阶用法:异步组件(vue 异步组件原理)

一、代码分割一个大型前端应用,如果所有代码都放在单一文件,体积会特别大,下载时间长,白屏时间久,用户体验差。...

源码补丁神器—patch-package(源码助手怎么用)

作者:张浩一、背景vue项目中使用vue-pdf第三方插件预览pdf,书写业务代码完美运行,pdf文件内容正常预览无问题。后期需求有变,业务需求增加电子签章功能。这个时候pdf文件的内容可以显示出...

经验分享:Vue2 项目升级 Vue3 + Element Plus,借助Deepseek手动升级

Vue3出来好久了,我开发的项目还在使用Vue2框架,一般情况下不考虑升级,但是最近需要接入工作流程引擎之类的,看了下Vue2生态下操作空间不是很好,那索性尝试升级Vue3吧。一番操作下来,升级成功,...

34K Star!史上最全JavaScript资源库 awesome-javascript

34KStar!史上最全JavaScript资源宝库大揭秘引言在GitHub上,有一个备受瞩目的JavaScript资源仓库,以其全面的内容和精心的分类,成为了众多开发者的必备参考。这个拥有超过...

基于 Vue.js 磁片栅格布局组件VueGridLayout

#头条创作挑战赛#今天给大家分享一个超优秀的vue.js拖拽栅格布局插件VueGridLayout。...

6款高颜值 Vue3 PC端UI组件库(vue3开发组件库)

马上到国庆了,还没学习或者想学习vue3的小伙伴们有安排上没?这次推荐几个比较流行的VUE3UI组件库,合理利用,又或者学习借鉴都是不错的选择。1、element-pluselement-plus...

高性能 vue.js+ztree 树形组件Vue-GiantTree

今天给大家分享一款超棒的Vue海量数据渲染树形组件VueGiantTree。vue-giant-tree基于ztree封装的Vue树形组件。轻松实现大数据高性能渲染,适合海量数据渲染场景。zTr...

【推荐】2024年推荐的6款开源免费 Vue 后台管理系统模板,建议收藏

前言在现今的软件开发领域,...