基于python的docx模块处理word和WPS的docx格式文件方式
作者:江户川柯壮 时间:2021-11-13 12:07:55
Python docx module for Word or WPS processing
本文是通过docx把word中的表格中的某些已填好的内容提取出来,存入excel表格。
首先安装docx的python模块:
pip install python-docx
由于处理的为中文和符号,改成utf-8编码格式
import sys
reload(sys)
sys.setdefaultencoding('utf-8')
from docx import Document
import pandas as pd
# 打开文件
doc = Document(ur'test_1.docx')
为了处理word中以对勾形式勾选的项目,采用下面 的方法
1、十字路口 √ 2、丁字路口 3、环形路口 4、人行立交
# 取出对号勾选的项目
print doc.tables[0].rows[3].cells[2].text
print doc.tables[0].rows[3].cells[2].text.split(u'√')[1].strip().split(' ')[0][2:]
'√' in doc.tables[0].rows[3].cells[2].text # 这个语句可以测试是否含有对勾,
# 有的话就取出对勾后面的item,否则直接返回填空的text
True
num_rows = len(doc.tables[0].rows)
print num_rows
xls = pd.read_csv(ur'output.csv')
print xls.columns[0]
diction = {}
# 找到每个excel文档中需要被记录的键值在docx文档表格中的位置
for xlskey in xls.columns:
for row_id in range(num_rows):
row = doc.tables[0].rows[row_id]
for cell_id in range(len(row.cells)):
if row.cells[cell_id].text.strip() == xlskey.strip():
diction[xlskey] = [row_id, cell_id]
# 查看一下获得的键值位置
for key in list(diction.keys()):
print key, diction[key]
楼层数 [21, 1]
宗地形状 [4, 1]
使用权取得时间 [14, 1]
采光通风状况 [19, 1]
已使用年限 [21, 4]
建筑朝向 [7, 1]
房屋结构 [17, 1]
交叉路口形式 [3, 1]
临街状况 [8, 1]
建筑容积率 [10, 5]
楼宇名称 [15, 5]
质量等级 [18, 1]
周围土地利用类型 [11, 1]
总建筑面积 [20, 1]
宗地位置 [0, 1]
所临道路名称 [2, 1]
装修标准 [16, 1]
那么我们认为这些表头键值对应的填入数据就在他们的右边,也就是下一个cell,因此我们只需要将row id不变,cell+1,就能取出填表内容。
# 开始填表!!!
for each_column in xls.columns:
pos = diction[each_column]
textion = doc.tables[0].rows[pos[0]].cells[pos[1] + 1].text
if u'√' in textion:
this_text = textion.strip(' ').split(u'√')[1].split()[0][2:]
else:
this_text = textion
xls.loc[0, each_column] = this_text
xls
楼宇名称 | 宗地位置 | 所临道路名称 | 交叉路口形式 | 宗地形状 | 建筑朝向 | 临街状况 | 周围土地利用类型 | 装修标准 | 房屋结构 | 质量等级 | 采光通风状况 | 总建筑面积 | 楼层数 | 已使用年限 | 建筑容积率 | 使用权取得时间 | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
0 | 百兴花园 | 鄂州市鄂城区凤凰路47-11号 | 凤凰路 | 丁字路口 | 多边形 | 南 | 离街 | 商业用地 | 豪华 | 1、钢 2、钢、钢混 3、钢混 4、混合 5、砖木 6、其它 | 完好 | 好 | 122.7平方米 | 8 | 13年 |
Succeed!!!
之后只需要用一个glob函数取出所有的文档的path,然后依次执行上面的命令,即可完成word表格到excel(实际上是csv形式)的自动填表过程。
来源:https://blog.csdn.net/edogawachia/article/details/80394745
标签:python,docx,word,WPS,docx
0
投稿
猜你喜欢
vue中的面包屑导航组件实例代码
2024-05-02 17:11:28
javascript中select下拉框的用法总结
2024-04-19 09:57:51
网页中英文混排行高不等问题
2008-08-26 17:03:00
Python实现对图像加噪(高斯噪声 椒盐噪声)
2023-06-15 03:08:34
asp 获取url函数小结
2011-03-17 10:38:00
Python3 pywin32模块安装的详细步骤
2023-01-20 06:42:46
Python监听剪切板实现方法代码实例
2023-11-10 13:48:32
MySQL建立唯一索引实现插入重复自动更新
2024-01-12 13:46:36
Python中glob库实现文件名的匹配
2022-08-06 21:50:19
Linux VPS备份教程 数据库/网站文件自动定时备份
2024-01-14 21:41:42
基于python 将列表作为参数传入函数时的测试与理解
2023-02-07 19:51:18
Python真题案例之蛇形数组详解
2021-12-09 11:00:40
5步让你的CSS样式表成功减肥
2009-08-02 21:27:00
一个小时内学习 SQLite 数据库
2012-05-22 18:51:30
GO语言中回调函数的使用
2024-04-25 15:05:41
ThinkPHP的URL重写问题
2024-05-05 09:16:25
为什么要登录?
2010-11-30 21:41:00
MySQL主从原理及配置详解
2024-01-26 08:33:42
Windows环境下python环境安装使用图文教程
2023-12-25 10:13:26
MySQL 数据库 source 命令详解及实例
2024-01-15 10:50:58