Python办公自动化(一):从Word到Excel_python word range

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包的strptime和strftime函数:


* strptime: 解析字符串中蕴含的时间
* strftime: 转化成所需的时间格式



import datetime

n = 0
for 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 = 0
for 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()

获取当前sheet

sheet = 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 Document
import datetime
from openpyxl import Workbook

wb = Workbook()
sheet = wb.active
header = [‘序号’, ‘收文时间’, ‘办文编号’, ‘文件标题’, ‘文号’, ‘备注’]
sheet.append(header)

path = r’C:\Users\word.docx’
document = Document(path)
tables = document.tables

n = 0
for 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)
continue

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


参考链接 :  
 Python办公自动化(一):从Word到Excel :https://mp.weixin.qq.com/s/IMXqGfPVKNRk\_pvdtD35fA



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值