基于python的docx模块处理word和WPS的docx格式文件方式


Posted in Python onFebruary 13, 2020

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形式)的自动填表过程。

以上这篇基于python的docx模块处理word和WPS的docx格式文件方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python中的默认参数详解
Jun 24 Python
python中数据爬虫requests库使用方法详解
Feb 11 Python
Python OpenCV读取png图像转成jpg图像存储的方法
Oct 28 Python
对python:print打印时加u的含义详解
Dec 15 Python
python django model联合主键的例子
Aug 06 Python
Python中__repr__和__str__区别详解
Nov 07 Python
详谈tensorflow gfile文件的用法
Feb 05 Python
Python如何实现FTP功能
May 28 Python
python在地图上画比例的实例详解
Nov 13 Python
pymongo insert_many 批量插入的实例
Dec 05 Python
Python实现给PDF添加水印的方法
Jan 25 Python
Pytorch distributed 多卡并行载入模型操作
Jun 05 Python
python 中的[:-1]和[::-1]的具体使用
Feb 13 #Python
Python使用docx模块实现刷题功能代码
Feb 13 #Python
Tensorflow训练MNIST手写数字识别模型
Feb 13 #Python
Python3 读取Word文件方式
Feb 13 #Python
解决Python import docx出错DLL load failed的问题
Feb 13 #Python
python求最大公约数和最小公倍数的简单方法
Feb 13 #Python
python圣诞树编写实例详解
Feb 13 #Python
You might like
php中{}大括号是什么意思
2013/12/01 PHP
php中current、next与reset函数用法实例
2014/11/17 PHP
PHP读取CSV大文件导入数据库的实例
2017/07/24 PHP
ExtJS PropertyGrid中使用Combobox选择值问题
2010/06/13 Javascript
如何确保JavaScript的执行顺序 之jQuery.html深度分析
2011/03/03 Javascript
js 限制input只能输入数字、字母和汉字等等
2013/12/18 Javascript
jquery删除提示框弹出是否删除对话框
2014/01/07 Javascript
基于jQuery的图片不完全按比例自动缩小
2014/07/11 Javascript
jQuery实现tab标签自动切换的方法
2015/02/28 Javascript
javascript中关于&& 和 || 表达式的小技巧分享
2015/04/10 Javascript
Jquery幻灯片特效代码分享--打开页面随机选择切换方式(3)
2015/08/15 Javascript
Jquery组件easyUi实现表单验证示例
2016/08/23 Javascript
vue中将网页打印成pdf实例代码
2017/06/15 Javascript
微信小程序实现带缩略图轮播效果
2018/11/04 Javascript
JavaScript实现邮箱后缀提示功能的示例代码
2018/12/13 Javascript
用Cordova打包Vue项目的方法步骤
2019/02/02 Javascript
webpack自动打包和热更新的实现方法
2019/06/24 Javascript
vue-video-player实现实时视频播放方式(监控设备-rtmp流)
2020/08/10 Javascript
Openlayers实现扩散的动态点(水纹效果)
2020/08/17 Javascript
详解JavaScript中new操作符的解析和实现
2020/09/04 Javascript
[04:23]DOTA2上海特锦赛小组赛第一日 TOP10精彩集锦
2016/02/27 DOTA
python通过scapy获取局域网所有主机mac地址示例
2014/05/04 Python
django轻松使用富文本编辑器CKEditor的方法
2017/03/30 Python
Python排序算法之选择排序定义与用法示例
2018/04/29 Python
浅析PHP与Python进行数据交互
2018/05/15 Python
Python切片索引用法示例
2018/05/15 Python
python制作mysql数据迁移脚本
2019/01/01 Python
Python assert关键字原理及实例解析
2019/12/13 Python
python实现用户名密码校验
2020/03/18 Python
python 给图像添加透明度(alpha通道)
2020/04/09 Python
pytorch快速搭建神经网络_Sequential操作
2020/06/17 Python
零基础小白多久能学会python
2020/06/22 Python
美国在线精品家居网站:Burke Decor
2017/04/12 全球购物
开业庆典主持词
2014/03/21 职场文书
学雷锋日活动总结
2015/02/06 职场文书
CSS3 实现NES游戏机的示例代码
2021/04/21 HTML / CSS