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

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格式文件方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

在Linux系统中,使用Python调用WPS Office的可执行程序将doc格式文件转换成docx格式,你需要确保WPS Office已经安装在你的系统上,并且你有相应的权限来执行这个转换操作。以下是一个简单的步骤指南和示例代码: 步骤指南: 1. 确定WPS Office的安装路径,通常它会安装在`/opt/kingsoft`目录下,但这可能会根据不同的Linux发行版和安装方式而有所不同。 2. 找到WPS Office的可执行程序,通常是`wps`或者`wpp`,并且找到转换命令`wpsconvert`。 3. 使用Python的`subprocess`模块来调用这些可执行程序和命令。 示例代码: ```python import subprocess def convert_doc_to_docx(input_file_path, output_file_path): # 确保输入路径和输出路径存在 input_file_path = input_file_path output_file_path = output_file_path # 假设wpsconvert位于/opt/kingsoft/wps-office64/program目录下 wpsconvert_path = "/opt/kingsoft/wps-office64/program/wpsconvert" # 构建转换命令 command = [wpsconvert_path, input_file_path, output_file_path] # 调用系统命令执行转换 process = subprocess.run(command, stdout=subprocess.PIPE, stderr=subprocess.PIPE) # 检查命令是否执行成功 if process.returncode == 0: print(f"文件已成功从 {input_file_path} 转换为 {output_file_path}") else: print(f"转换失败: {process.stderr.decode()}") # 使用示例 convert_doc_to_docx('/path/to/input.doc', '/path/to/output.docx') ``` 注意事项: - 请根据你的实际安装路径和WPS版本调整`wpsconvert_path`变量。 - 确保你有足够的权限来执行这个脚本,可能需要使用`sudo`来运行。 - 上述代码没有包含错误处理的全部细节,实际使用时应增加相应的异常处理
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值