使用python批量读取word文档并整理关键信息到excel表格的实例


Posted in Python onNovember 07, 2018

目标

最近实验室里成立了一个计算机兴趣小组

倡议大家多把自己解决问题的经验记录并分享

就像在CSDN写博客一样

虽然刚刚起步

但考虑到后面此类经验记录的资料会越来越多

所以一开始就要做好模板设计(如下所示)

使用python批量读取word文档并整理关键信息到excel表格的实例

方便后面建立电子数据库

从而使得其他人可以迅速地搜索到相关记录

据说“人生苦短,我用python”

所以决定用python从docx文档中提取文件头的信息

然后把信息更新到一个xls电子表格中,像下面这样(直接po结果好了)

使用python批量读取word文档并整理关键信息到excel表格的实例

而且点击文件路径可以直接打开对应的文件(含超链接)

使用python批量读取word文档并整理关键信息到excel表格的实例

代码实现

1. 采集docx里面文件头信息

# -*- coding:utf-8 -*-
 
# 此程序可扫描Log中的docx文件并返回基本信息
 
import docx
from docx import Document
 
test_d = '../log/sublime搭建python的集成开发环境.docx'
 
def docxInfo(addr):
 document = Document(addr)
 
 info = {'title':[],
 'keywords':[],
 'author':[],
 'date':[],
 'question':[]}
 
 lines = [0 for i in range(len(document.paragraphs))]
 k = 0
 for paragraph in document.paragraphs:
 lines[k] = paragraph.text
 k = k+1
 
 index = [0 for i in range(5)]
 k = 0
 for line in lines:
 if line.startswith('标题'):
 index[0] = k
 if line.startswith('关键词'):
 index[1] = k
 if line.startswith('作者'):
 index[2] = k
 if line.startswith('日期'):
 index[3] = k
 if line.startswith('问题描述'):
 index[4] = k
 k = k+1
 
 info['title'] = lines[index[0]+1]
 
 keywords = []
 for line in lines[index[1]+1:index[2]]:
 keywords.append(line)
 info['keywords'] = keywords
 
 info['author'] = lines[index[2]+1]
 
 info['date'] = lines[index[3]+1]
 
 info['question'] = lines[index[4]+1]
 
 return info
 
if __name__ == '__main__':
 print(docxInfo(test_d))

2. 遍历log文件夹,进行信息更新

# -*- coding:utf-8 -*-
 
# 此程序可以批量扫描log中的文件,如果碰到docx文档,
# 则调用readfile()提取文档信息,并将信息保存到digger
# 日志列表.xls之中,方便后期快速检索
 
import os,datetime
import time
import xlrd
from xlrd import xldate_as_tuple
import xlwt
from readfile import docxInfo
from xlutils.copy import copy
 
# 打开日志列表读取最近一条记录的更新日期
memo_d = '../log/digger日志列表.xls'
memo = xlrd.open_workbook(memo_d) #读取excel
sheet0 = memo.sheet_by_index(0) #读取第1张表
memo_date = sheet0.col_values(5) #读取第5列
memo_n = len(memo_date) #去掉标题
if memo_n>0:
 xlsx_date = memo_date[memo_n-1] #读取最后一条记录的日期,
 latest_date = sheet0.cell_value(memo_n-1,5)
 # 返回时间戳
 
# 新建一个xlsx
memo_new = copy(memo)
sheet1 = memo_new.get_sheet(0)
 
# 重建超链接
hyperlinks = sheet0.col_values(6) # xlrd读取的也是text,造成超链接丢失
k = 1
n_hyperlink = len(hyperlinks)
for k in range(n_hyperlink):
 link = 'HYPERLINK("%s";"%s")' %(hyperlinks[k],hyperlinks[k])
 sheet1.write(k,6,xlwt.Formula(link))
 k = k+1
 
 
# 判断文件后缀
def endWith(s,*endstring):
 array = map(s.endswith,endstring)
 if True in array:
  return True
 else:
  return False
 
# 遍历log文件夹并进行查询
log_d = '../log'
logFiles = os.listdir(log_d)
for file in logFiles:
 if endWith(file,'.docx'):
 timestamp = os.path.getmtime(log_d+'/'+file)
 if timestamp>latest_date:
 info = docxInfo(log_d+'/'+file)
 sheet1.write(memo_n,0,info['title'])
 keywords_text = ','.join(info['keywords'])
 sheet1.write(memo_n,1,keywords_text)
 sheet1.write(memo_n,2,info['author'])
 sheet1.write(memo_n,3,info['date'])
 sheet1.write(memo_n,4,info['question'])
 #获取当前时间
 time_now = time.time() #浮点值,精确到毫秒
 sheet1.write(memo_n,5, time_now)
 link = 'HYPERLINK("%s";"%s")' %(file,file)
 sheet1.write(memo_n,6,xlwt.Formula(link))
 memo_n = memo_n+1
os.remove(memo_d)
memo_new.save(memo_d)
print('memo was updated!')

其实还有一些操作电子表格更好的模块,比如panda、xlsxwriter、openpyxl等。不过上述代码已经基本能实现功能,而且科研狗毕竟没那么多时间写代码做调试,所以后面有空再update吧!

致谢

在此过程中大量借鉴了CSDN论坛中各位大神的各种经验!!!

以上这篇使用python批量读取word文档并整理关键信息到excel表格的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python函数式编程
Jul 20 Python
python调用系统ffmpeg实现视频截图、http发送
Mar 06 Python
Python中的集合介绍
Jan 28 Python
python实现微信定时每天和女友发送消息
Apr 29 Python
Python完成毫秒级抢淘宝大单功能
Jun 06 Python
解决Python中pandas读取*.csv文件出现编码问题
Jul 12 Python
django搭建项目配置环境和创建表过程详解
Jul 22 Python
如何利用Python开发一个简单的猜数字游戏
Sep 22 Python
pandas中遍历dataframe的每一个元素的实现
Oct 23 Python
Python使用Selenium模拟浏览器自动操作功能
Sep 08 Python
Python urlopen()参数代码示例解析
Dec 10 Python
python文件路径操作方法总结
Dec 21 Python
使用PM2+nginx部署python项目的方法示例
Nov 07 #Python
python读取word文档,插入mysql数据库的示例代码
Nov 07 #Python
pandas.DataFrame删除/选取含有特定数值的行或列实例
Nov 07 #Python
python 返回列表中某个值的索引方法
Nov 07 #Python
pandas 根据列的值选取所有行的示例
Nov 07 #Python
Pandas过滤dataframe中包含特定字符串的数据方法
Nov 07 #Python
pandas筛选某列出现编码错误的解决方法
Nov 07 #Python
You might like
PHP下用rmdir实现删除目录的三种方法小结
2008/04/20 PHP
下拉列表多级联动dropDownList示例代码
2013/06/27 PHP
php中stdClass的用法分析
2015/02/27 PHP
PHP读取配置文件类实例(可读取ini,yaml,xml等)
2015/07/28 PHP
PHP实现图片压缩
2020/09/09 PHP
PHP的垃圾回收机制代码实例讲解
2021/02/27 PHP
15条JavaScript最佳实践小结
2013/08/09 Javascript
在JS中如何调用JSP中的变量
2014/01/22 Javascript
jquery实现html页面 div 假分页有原理有代码
2014/09/06 Javascript
javascript常用方法总结
2015/05/14 Javascript
基于Jquery制作图片文字排版预览效果附源码下载
2015/11/18 Javascript
带有定位当前位置的百度地图前端web api实例代码
2016/06/21 Javascript
JS获取html元素的标记名实现方法
2016/10/08 Javascript
原生js验证简洁注册登录页面
2016/12/17 Javascript
angularJs使用$watch和$filter过滤器制作搜索筛选实例
2017/06/01 Javascript
JavaScript 值类型和引用类型的初次研究(推荐)
2017/07/19 Javascript
vue router-link传参以及参数的使用实例
2017/11/10 Javascript
Vue2.0用户权限控制解决方案
2017/11/29 Javascript
vue.js中$set与数组更新方法
2018/03/08 Javascript
JQuery属性操作与循环用法示例
2019/05/15 jQuery
Vue时间轴 vue-light-timeline的用法说明
2020/10/29 Javascript
vue $router和$route的区别详解
2020/12/02 Vue.js
Python字符串特性及常用字符串方法的简单笔记
2016/01/04 Python
python实现人脸识别经典算法(一) 特征脸法
2018/03/13 Python
对python读取CT医学图像的实例详解
2019/01/24 Python
将python文件打包成EXE应用程序的方法
2019/05/22 Python
Python使用jpype模块调用jar包过程解析
2020/07/29 Python
python获取linux系统信息的三种方法
2020/10/14 Python
python 列表推导和生成器表达式的使用
2021/02/01 Python
阿拉伯世界最大的电子商务网站:Souq沙特阿拉伯
2016/10/28 全球购物
荷兰睡眠专家:Beter Bed
2020/11/23 全球购物
离婚协议书怎样才有法律效力
2014/10/10 职场文书
2015年主婚人婚礼致辞
2015/07/28 职场文书
小学中队委竞选稿
2015/11/20 职场文书
Windows下用Nginx配置https服务器及反向代理的问题
2021/09/25 Servers
详解Vue router路由
2021/11/20 Vue.js