一、修改数据类型(中英)

需求:

代码:

#-*-coding:gbk*-
import os
import docx
#from docx.enum.table import WD_TABLE_ALIGNMENT
from docx.enum.text import WD_ALIGN_PARAGRAPH filepath = r'f:/1/'
def main():
docxlist = os.listdir(filepath)
for mydocx in docxlist:
newdocx = docx.Document(filepath + str(mydocx))
#newdocx.paragraph_format.alignment = WD_ALIGN_PARAGRAPH.CENTER
table = newdocx.tables
for oTable in table:
rows_num = len(oTable.rows)
columns_num = len(oTable.columns)
if columns_num >= 5:
for j in range(rows_num):
#English -> Chinese
ostring = oTable.cell(j, 3).text
oTable.cell(j, 4).paragraphs[0].paragraph_format.alignment = WD_ALIGN_PARAGRAPH.CENTER
if ostring == 'TIMESTAMP':
oTable.cell(j, 3).text = ostring.replace("TIMESTAMP", "时间戳")
oTable.cell(j, 4).text = ""
elif ostring == 'VARCHAR2':
oTable.cell(j, 3).text = ostring.replace("VARCHAR2", "字符串")
if ostring == 'DATE':
oTable.cell(j, 3).text = ostring.replace("DATE", "日期")
oTable.cell(j, 4).text = ""
elif ostring == 'NUMBER':
oTable.cell(j, 3).text = ostring.replace("NUMBER", "整数")
elif ostring == 'FLOAT':
oTable.cell(j, 3).text = ostring.replace("FLOAT", "小数")
#oTable.alignment = WD_TABLE_ALIGNMENT.CENTER
newdocx.save('f:/2/'+ str(mydocx))
if __name__ == '__main__':
main()

二、数据类型为日期时,清空位数内容

需求:

代码:

#!/usr/bin/python3
# -*- coding: utf-8 -*-
# @Time : 2019/2/20 14:12
# @File : date_del.py from docx import Document # 导入库
"""
word表格中
"""
path = "C:\\Users\\1\\Desktop\\福建省质监局标准信息资源目录.docx" # 文件路径
document = Document(path) # 读入文件
tables = document.tables # 获取文件中的表格集
one_cells = []
for table in tables:
rows_num = len(table.rows)
columns_num = len(table.columns)
if rows_num > 2 and columns_num == 4:
for i in range(1, rows_num): # 第二行开始
if table.cell(i, 3).text == '日期' or table.cell(i, 1).text == '日期':
one_cells.append(table.cell(0, 1).text)
for j in range(0, columns_num):
if table.cell(0, 1).text in one_cells:
if table.cell(i, j).text == '位数':
table.cell(i, j + 1).text = '' document.save("C:\\Users\\1\\Desktop\\1\\福建省质监局标准信息资源目录.docx")
# 校验修改内容
for i in one_cells:
print(i)

三、表格中添加单元格

需求:

参考:https://www.jianshu.com/p/9da61bf35cb7

代码:

#!/usr/bin/python3
# -*- coding: utf-8 -*-
# @Time : 2019/2/25 9:52
# @File : table_add_cell.py from docx import Document
from docx.enum.text import WD_ALIGN_PARAGRAPH
from docx.oxml.ns import qn
from docx.shared import Pt """
word表格,添加一个单元格以及内容
"""
path = "C:\\Users\\1\\Desktop\\成都市质量技术监督局标准层信息资源目录.docx" # 文件路径
document = Document(path) # 读入文件
# 设置字体为: 宋体
document.styles['Normal'].font.name = u'宋体'
document.styles['Normal']._element.rPr.rFonts.set(qn('w:eastAsia'), u'宋体') tables = document.tables # 获取文件中的tables
# 被修改表格的列表
one_cells = [] def match_table():
"""
遍历文档匹配满足条件的表格
:return:
"""
for table in tables:
rows_num = len(table.rows)
columns_num = len(table.columns)
if rows_num > 2 and columns_num == 4:
one_text = table.cell(0, 1).text
if len(one_text) == 29:
one_cells.append(one_text) end_text = table.cell(rows_num - 1, columns_num - 1).text
if end_text:
# 添加一行
table.add_row()
set_font(table, 5, 0)
else:
set_font(table, rows_num - 1, columns_num - 2)
document.save("C:\\Users\\1\\Desktop\\1\\python_word_table_add_cell.docx") def set_font(table, a, b):
"""
设置表格字体样式
:param table: 表格
:param a: 行坐标
:param b: 列坐标
:return:
"""
run = table.cell(a, b).paragraphs[0].add_run(u'信息资源生产格式') # 内容为:信息资源生产格式
run.bold = True # 加粗
run.font.size = Pt(9) # 字体大小:小五-9
table.cell(a, b).paragraphs[0].alignment = WD_ALIGN_PARAGRAPH.CENTER # 居中 run1 = table.cell(a, b + 1).paragraphs[0].add_run(u'ORACLE')
run1.font.size = Pt(9)
table.cell(a, b + 1).paragraphs[0].alignment = WD_ALIGN_PARAGRAPH.CENTER def check_data():
# 校验修改内容
for i in one_cells:
print(i) if __name__ == '__main__':
match_table()
check_data()

python-docx编辑word表格的更多相关文章

  1. C#使用Docx操作word文档

    C#使用Docx编写word表格 最近接手了一个小Demo,要求使用Docx,将Xml文件中的数据转换为word文档,组织数据形成表格. 写了已经一周,网络上的知识太零碎,就想自己先统计整理出来,方便 ...

  2. Python批量创建word文档(2)- 加图片和表格

    Python创建word文档,任务要求:小杨在一家公司上班,每天都需要给不同的客户发送word文档,以告知客户每日黄金价格.要求在文档开始处给出banner条,价格日期等用表格表示.最后贴上自己的联系 ...

  3. python读取word表格内容(1)

    1.首页介绍下word表格内容,实例如下: 每两个表格后面是一个合并的单元格

  4. 【转】使用Docx.Core创建word表格

    原文地址:https://www.cnblogs.com/qs315/p/13533765.html 使用Docx.Core创建word表格 下载DocxCore Nuget包 当前版本 1.0.7 ...

  5. java web实现在线编辑word,并将word导出(二)

    前一篇文章介绍了后台将前台html转为word文档的一种方式,但却有一个问题是没法讲图片放置在生成的word报告中.我在网上找了很多方法,甚至将图片转换成base64编码的方式也不成功.效果如下: 由 ...

  6. 最全总结 | 聊聊 Python 办公自动化之 Word(中)

    1. 前言 上一篇文章,对 Word 写入数据的一些常见操作进行了总结 最全总结 | 聊聊 Python 办公自动化之 Word(上) 相比写入数据,读取数据同样很实用! 本篇文章,将谈谈如何全面读取 ...

  7. 最全总结 | 聊聊 Python 办公自动化之 Word(下)

    1. 前言 关于 Word 文档的读写,前面两篇文章分别进行了一次全面的总结 最全总结 | 聊聊 Python 办公自动化之 Word(上) 最全总结 | 聊聊 Python 办公自动化之 Word( ...

  8. Java 读取Word表格中的文本和图片

    本文通过Java程序来展示如何读取Word表格,包括读取表格中的文本和图片.下面是具体实现的步骤和方法. 1. 程序环境准备 代码编译工具:IntelliJ IDEA Jdk版本:1.8.0 测试文档 ...

  9. 在线编辑Word——插入图表

    在Word中可插入图表,配合使用表格能够更加全方位的展示数据的可信度并增加数据的可读性.本文将通过使用在线编辑器 Spire.Cloud Word 演示如何来插入图表,并设置相关格式化操作.具体步骤如 ...

随机推荐

  1. Openfire源码阅读(一)

    本篇先分析openfire源码的主要流程,模块细节后续再继续分析: 一.简介: Openfire是开源的实时协作服务器(RTC),它是基于公开协议XMPP(RFC-3920),并在此基础上实现了XMP ...

  2. html5 视频播放插件

    HTML5中加入了浏览器非常友好的标签 <video> ,这个标签非常的厉害,它可以不依靠falsh播放器,在网页中播放视频,目前W3C提供的video只支持mp4,ogg,webm三种视 ...

  3. TypeScript 之 基础类型、高级类型

    基础类型:https://m.runoob.com/manual/gitbook/TypeScript/_book/doc/handbook/Basic%20Types.html 高级类型:https ...

  4. 深入理解ASP.NET MVC(8)

    系列目录 过滤器上下文参数 前一节提到了四种MVC内建过滤器,它们无一例外都在关键的方法中提供了叫filterContext的参数,尽管它们各自类型不同,但是都继承自ControllerContext ...

  5. cmp命令详解

    Linux cmp命令 Linux cmp命令用于比较两个文件是否有差异.主要用来比较两个二进制文件 当相互比较的两个文件完全一样时,则该指令不会显示任何信息.若发现有所差异,预设会标示出第一个不同之 ...

  6. PHP中的插件机制原理和实例

    PHP项目中很多用到插件的地方,更尤其是基础程序写成之后很多功能由第三方完善开发的时候,更能用到插件机制,现在说一下插件的实现.特点是无论你是否激活,都不影响主程序的运行,即使是删除也不会影响. 从一 ...

  7. ML: 聚类算法R包-K中心点聚类

    K-medodis与K-means比较相似,但是K-medoids和K-means是有区别的,不一样的地方在于中心点的选取,在K-means中,我们将中心点取为当前cluster中所有数据点的平均值, ...

  8. Vivado HLS初识---阅读《vivado design suite tutorial-high-level synthesis》(4)

    Vivado HLS初识---阅读<vivado design suite tutorial-high-level synthesis>(4) 1.老样子,首先运行tcl脚本建工程: Vi ...

  9. windows环境下把Python代码打包成独立执行的exe

    windows环境下把Python代码打包成独立执行的exe可执行文件   有时候因为出差,突然急需处理一批数据.虽然写好的脚本存储在云端随用随取,然而编译的环境还需要重新搭建,模块也需要重新装载,从 ...

  10. CAD求交点函数

    public void IntersectWith( Entity entityPointer, Intersect intersectType, Point3dCollection points, ...