iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python办公自动化Word转Excel文件批量处理的方法
  • 466
分享到

Python办公自动化Word转Excel文件批量处理的方法

2023-07-02 14:07:25 466人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

本篇内容主要讲解“python办公自动化Word转excel文件批量处理的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python办公自动化Word转Excel文件批量处理的方法”吧!前言

本篇内容主要讲解“python办公自动化Wordexcel文件批量处理的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习Python办公自动化Word转Excel文件批量处理的方法”吧!

前言

大家好,今天有一个公务员的小伙伴委托我给他帮个忙,大概是有这样一份Word(由于涉及文件私密所以文中的具体内容已做修改)

Python办公自动化Word转Excel文件批量处理的方法

一共有近2600条类似格式的表格细栏,每个栏目包括的信息有:

  • 日期

  • 发文单位

  • 文号

  • 标题

  • 签收栏

需要提取其中加粗的这三项内容到Excel表格中存储,表格样式如下:

Python办公自动化Word转Excel文件批量处理的方法

也就是需要将收文时间、文件标题、文号填到指定位置,同时需要将时间修改为标准格式,如果是完全手动复制和修改时间,依照一个条目10s的时间计算,一分钟可以完成6条,那么最快也需要:

Python办公自动化Word转Excel文件批量处理的方法

而这类格式规整的文件整理非常适合用Python来执行,好的那么接下来请Python出场,必要的信息我在代码中以注释信息呈现。

首先使用Python将Word文件导入

# 导入需要的库docxfrom docx import Document# 指定文件存放的路径path = r'C:\Users\word.docx' # 读取文件document = Document(path)# 读取word中的所有表格tables = document.tables

再把问题逐个划分,首先尝试获取第一张表第一个文件条目的三个所需信息

# 获取第一张表table0 = tables[0]

仔细观察可以发现一个文件条目占据了3行,所以对表格全部行循环迭代时可以设步长为3

Python办公自动化Word转Excel文件批量处理的方法

row和cell解析所需内容

注意观察表格,按照row和cell把所需内容解析清楚

# 在全局放一个变量用来计数填序号n = 0for i in range(0, len(table0.rows) + 1, 3):    # 日期    date = table0.cell(i, 1).text    # 标题    title = table0.cell(i + 1, 1).text.strip()    # 文号    dfn = tables[j].cell(i, 3).text.strip()    print(n, date, tite, dfn)

接下来需要解决的是,时间我们获取的是 2/1 这种 日/月的形式。我们需要转化成 YYYY-MM-DD格式,而这利用到datetime包的strptimestrftime函数:

strptime: 解析字符串中蕴含的时间

strftime: 转化成所需的时间格式

import datetimen = 0for i in range(0, len(table0.rows) + 1, 3):    # 日期    date = table0.cell(i, 1).text    # 有的条目时间是空的,这里不做过多判别    if '/' in date:        date = datetime.datetime.strptime(date, '%d/%m').strftime('2020-%m-%d')    else:        date = '-'    # 标题    title = table0.cell(i + 1, 1).text.strip()    # 文号    dfn = tables[j].cell(i, 3).text.strip()    print(n, date, tite, dfn)

这样一张表的内容解析就完成了,注意这里用的是table[0]即第一张表,遍历所有的表加一个嵌套循环就可以,另外也可以捕获异常增加程序灵活性

n = 0for j in range(len(tables)):    for i in range(0, len(tables[j].rows)+1, 3):        try:            # 日期            date = tables[j].cell(i, 1).text            if '/' in date:                date = datetime.datetime.strptime(date, '%d/%m').strftime('2020-%m-%d')            else:                date = '-'            # 标题            title = tables[j].cell(i + 1, 1).text.strip()            # 文号            dfn = tables[j].cell(i, 3).text.strip()            n += 1            print(n, date, title, dfn)        except Exception as error:            # 捕获异常,也可以用log写到日志里方便查看和管理            print(error)            continue

信息解析和获取完成就可以导出了,用到的包是openpyxl

from openpyxl import Workbook# 实例化wb = Workbook()# 获取当前sheetsheet = wb.active# 设立表头header = ['序号', '收文时间', '办文编号', '文件标题', '文号', '备注']sheet.append(header)

内层解析循环

在最内层解析循环的末尾加上如下代码即可

row = [n, date, ' ', title, dfn, ' ']sheet.append(row)

线程的最后记得保存

wb.save(r'C:\Users\20200420.xlsx')

运行时间在10分钟左右,大概离开了一会程序就执行结束了

最后附上完整代码,代码很简单,理清思路最重要

from docx import Documentimport datetimefrom openpyxl import Workbookwb = Workbook()sheet = wb.activeheader = ['序号', '收文时间', '办文编号', '文件标题', '文号', '备注']sheet.append(header)path = r'C:\Users\word.docx'document = Document(path)tables = document.tablesn = 0for j in range(len(tables)):    for i in range(0, len(tables[j].rows)+1, 3):        try:            # 日期            date = tables[j].cell(i, 1).text            if '/' in date:                date = datetime.datetime.strptime(date, '%d/%m').strftime('2020-%m-%d')            else:                date = '-'            # 标题            title = tables[j].cell(i + 1, 1).text.strip()            # 文号            dfn = tables[j].cell(i, 3).text.strip()            n += 1            print(n, date, title, dfn)            row = [n, date, ' ', title, dfn, ' ']            sheet.append(row)        except Exception as error:            # 捕获异常,也可以用log写到日志里方便查看和管理            print(error)            continuewb.save(r'C:\Users\20200420.xlsx')

到此,相信大家对“Python办公自动化Word转Excel文件批量处理的方法”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: Python办公自动化Word转Excel文件批量处理的方法

本文链接: https://www.lsjlt.com/news/342437.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Python办公自动化Word转Excel文件批量处理的方法
    本篇内容主要讲解“Python办公自动化Word转Excel文件批量处理的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python办公自动化Word转Excel文件批量处理的方法”吧!前言...
    99+
    2023-07-02
  • Python办公自动化Word转Excel文件批量处理
    目录前言首先使用Python将Word文件导入row和cell解析所需内容内层解析循环前言 大家好,今天有一个公务员的小伙伴委托我给他帮个忙,大概是有这样一份Word(由于...
    99+
    2022-11-11
  • Python 自动化处理Excel和Word实现自动办公
    今天我来分享一些Python办公自动化的方法,欢迎收藏学习,喜欢点赞支持,欢迎畅聊。 Openpyxl Openpyxl 可以说是 Python 中最通用的工具模块了,它使与 Exc...
    99+
    2022-11-12
  • Python办公自动化解决world文件批量转换
    目录python-docx 库简介读取 Word写入 WordWord 转 pdf最后的话 只要是简单重复的工作,就想办法用 Python 来帮你解决吧,人生苦短,你需要 Pytho...
    99+
    2022-11-12
  • Python办公自动化批量处理文件实现示例
    目录引言需求分析Python实现结束语引言 要说在工作中最让人头疼的就是用同样的方式处理一堆文件夹中文件,这并不难,但就是繁。所以在遇到机械式的操作时一定要记得使用Python来合理...
    99+
    2022-11-11
  • python自动化办公之批量修改文件名实操
    目录1. 程序背景2. 程序要求3. 解决思路4. 完整代码5. 运行结果6. 总结1. 程序背景 之前做文件批量移动的时候不小心多加了一个pdf后缀,但问题不大,几行代码就可以搞定...
    99+
    2022-11-11
  • Python自动化办公之Word文件内容的读取
    目录前言利用 python 批量读取文件word利器之python-docxpython-docx 安装python-docx 之 Documentpython-docx 之段落内容...
    99+
    2022-11-11
  • Python实现自动化处理Word文档的方法详解
    目录1. 批量生成Word文档2. 将Word文档批量转换成PDF3. 在Word文档中批量标记关键词4. 在Word文档中批量替换关键词使用Python实现Word文档的自动化处理...
    99+
    2022-11-11
  • Python 库 PySimpleGUI 制作自动化办公小软件的方法
    目录1 PySimpleGUI安装2 PySimpleGUI制作简易弹窗界面2.1 两种界面设计模式2.2 制作弹窗2.3 文字内容弹窗2.4 获取用户输入的弹窗2.5 文件选择弹出...
    99+
    2022-11-12
  • python 自动化将markdown文件转成html文件的方法
    一、背景 我们项目开发人员写的文档都是markdown文件。对于其它组的同学要进行阅读不是很方便。每次编辑完markdown文件,我都是用软件将md文件转成html文件。刚开始转的时候,还没啥,转得次数多...
    99+
    2022-06-04
    文件 转成 方法
  • python中的netCDF4批量处理NC文件的操作方法
    目录一、使用ArcMap提取出第一期数据1.使用工具箱中的“Make NetCDF Raster Layer”工具,提取出一个数据2.导出该数据作为标准数据二...
    99+
    2022-11-13
  • Python实现自动化处理PDF文件的方法详解
    目录自动化处理PDF文件1. 批量合并PDF文件2. 批量拆分PDF文件3. 批量加密PDF文件4. 批量PDF添加水印完整代码自动化处理PDF文件 使用Python完成简单的PDF...
    99+
    2022-11-11
  • 教你在Excel中调用Python脚本实现数据自动化处理的方法
    目录一、为什么将Python与Excel VBA集成?二、为什么使用xlwings?三、玩转xlwings这次我们会介绍如何使用xlwings将Python和Excel两大数据工具进...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作