Python自动化办公能做到的事可太多了

常用如下:

python 使用 python-docx 操作 word

1、python-docx 库介绍

* 该模块儿可以创建、修改 Word(.docx)文件;

* 此模块儿不属于 python 标准库,需要单独安装;

* 我们在安装此模块儿使用的是 pip install python-docx,但是在导入的时候是 import

docx;

2、Python 读取 Word 文档内容

* 注意:每进行一个操作,必须保存一下,否则等于白做;

1)word 文档结构介绍

2)python-docx 提取文字和文字块儿

① python-docx 提取文字

有一个这样的 docx 文件,我们想要提取其中的文字,应该怎么做?

代码如下:

from docx import Document

doc = Document(r"G:\6Tipdm\7python 办公自动化\concat_word\test1.docx")

print(doc.paragraphs)

for paragraph in doc.paragraphs:

print(paragraph.text)

结果如下:

② python-docx 提取文字块儿

from docx import Document

doc = Document(r"G:\6Tipdm\7python 办公自动化\concat_word\test1.docx")

print(doc.paragraphs)

paragraph = doc.paragraphs[0]

runs = paragraph.runs

print(runs)

for run in paragraph.runs:

print(run.text)

paragraph = doc.paragraphs[1]

runs = paragraph.runs

print(runs)

for run in paragraph.runs:

print(run.text)

结果如下:

3)利用 Python 向 Word 文档写入内容

① 添加段落

from docx import Document

doc = Document(r"G:\6Tipdm\7python 办公自动化\concat_word\test1.docx")

# print(doc.add_heading("一级标题", level=1)) 添加一级标题的时候出错,还没有

解决! paragraph1 = doc.add_paragraph("这是一个段落")

paragraph2 = doc.add_paragraph("这是第二个段落")

doc.save(r"G:\6Tipdm\7python 办公自动化\concat_word\test1.docx")

"""

添加段落的时候,赋值给一个变量,方便我们后面进行格式调整;

"""

结果如下:

② 添加文字块儿

from docx import Document

doc = Document(r"G:\6Tipdm\7python 办公自动化\concat_word\test1.docx")

# 这里相当于输入了一个空格,后面等待着文字输入

paragraph3 = doc.add_paragraph()

paragraph3.add_run("我被加粗了文字块儿").bold = True

paragraph3.add_run(",我是普通文字块儿,")

paragraph3.add_run("我是斜体文字块儿").italic = True

doc.save(r"G:\6Tipdm\7python 办公自动化\concat_word\test1.docx")

结果如下:

③ 添加一个分页

from docx import Document

doc = Document(r"G:\6Tipdm\7python 办公自动化\concat_word\test1.docx")

doc.add_page_break()

doc.save(r"G:\6Tipdm\7python 办公自动化\concat_word\test1.docx")

结果如下:

④ 添加图片

from docx import Document

from docx.shared import Cm

doc = Document(r"G:\6Tipdm\7python 办公自动化\concat_word\test1.docx")

doc.add_picture(r"G:\6Tipdm\7python 办公自动化

\concat_word\sun_wu_kong.png",width=Cm(5),height=Cm(5))

doc.save(r"G:\6Tipdm\7python 办公自动化\concat_word\test1.docx")

"""

Cm 模块,用于设定图片尺寸大小

"""

结果如下:

⑤ 添加表格

from docx import Document

doc = Document(r"G:\6Tipdm\7python 办公自动化\concat_word\test1.docx")

list1 = [

["姓名","性别","家庭地址"],

["唐僧","男","湖北省"],

["孙悟空","男","北京市"],

["猪八戒","男","广东省"],

["沙和尚","男","湖南省"]

]

list2 = [

["姓名","性别","家庭地址"],

["貂蝉","女","河北省"],

["杨贵妃","女","贵州省"],

["西施","女","山东省"]

]

table1 = doc.add_table(rows=5,cols=3)

for row in range(5):

cells = table1.rows[row].cells

for col in range(3):

cells[col].text = str(list1[row][col])

doc.add_paragraph("---------------------------------------------------------

--") table2 = doc.add_table(rows=4,cols=3)

for row in range(4):

cells = table2.rows[row].cells

for col in range(3):

cells[col].text = str(list2[row][col])

doc.save(r"G:\6Tipdm\7python 办公自动化\concat_word\test1.docx")

结果如下:

⑥ 提取 word 表格,并保存在 excel 中(很重要)

from docx import Document

from openpyxl import Workbook

doc = Document(r"G:\6Tipdm\7python 办公自动化\concat_word\test2.docx")

t0 = doc.tables[0]

workbook = Workbook()

sheet = workbook.active

for i in range(len(t0.rows)):

list1 = []

for j in range(len(t0.columns)):

list1.append(t0.cell(i,j).text)

sheet.append(list1)

workbook.save(filename = r"G:\6Tipdm\7python 办公自动化\concat_word\来自 word

中的表.xlsx")

结果如下:

3、利用 Python 调整 Word 文档样式

1)修改文字字体样式

from docx import Document

from docx.shared import Pt,RGBColor

from docx.oxml.ns import qn

doc = Document(r"G:\6Tipdm\7python 办公自动化\concat_word\test2.docx")

for paragraph in doc.paragraphs:

for run in paragraph.runs:

run.font.bold = True

run.font.italic = True

run.font.underline = True

run.font.strike = True

run.font.shadow = True

run.font.size = Pt(18)

run.font.color.rgb = RGBColor(255,255,0)

run.font.name = "宋体"

# 设置像宋体这样的中文字体,必须添加下面 2 行代码

r = run._element.rPr.rFonts

r.set(qn("w:eastAsia"),"宋体")

doc.save(r"G:\6Tipdm\7python 办公自动化\concat_word\_test1.docx")

结果如下:

2)修改段落样式

① 对齐样式

from docx import Document

from docx.enum.text import WD_ALIGN_PARAGRAPH

doc = Document(r"G:\6Tipdm\7python 办公自动化\concat_word\test1.docx")

print(doc.paragraphs[0].text)

doc.paragraphs[0].alignment = WD_ALIGN_PARAGRAPH.CENTER

# 这里设置的是居中对齐

doc.save(r"G:\6Tipdm\7python 办公自动化\concat_word\对齐样式.docx")

"""

居中对齐是其中一种样式,这里还有其他选择,自己百度了解:

LEFT,CENTER,RIGHT,JUSTIFY,DISTRIBUTE,JUSTIFY_MED,JUSTIFY_HI,JUSTIFY_LOW,THAI

_JUSTIFY

"""

结果如下:

② 行间距调整

from docx import Document

from docx.enum.text import WD_ALIGN_PARAGRAPH

doc = Document(r"G:\6Tipdm\7python 办公自动化\concat_word\test1.docx")

for paragraph in doc.paragraphs:

paragraph.paragraph_format.line_spacing = 5.0

doc.save(r"G:\6Tipdm\7python 办公自动化\concat_word\行间距.docx")

结果如下:

③ 段前与段后间距

* 这里提供代码,自行下去检验

......火遍全网!3天学会Python自动化办公!(附网盘链接和提取码)​mp.weixin.qq.com知乎:豆花花 - 资料汇总​ke.magedu.com

70后的人用python自动化办公_用 Python 自动化办公能做到哪些有趣或有用的事情?...相关推荐

  1. 用python自动化办公_知乎1800赞 | 用Python自动化办公能做到哪些有趣或有用的事情?...

    原标题:知乎1800赞 | 用Python自动化办公能做到哪些有趣或有用的事情? 知友:陈廷聿(1800+ 赞同) 利益相关:Python办公自动化课程的讲师 我想介绍一下我是如何从每天工作8小时,进 ...

  2. python 时间序列预测_使用Python进行动手时间序列预测

    python 时间序列预测 Time series analysis is the endeavor of extracting meaningful summary and statistical ...

  3. python 概率分布模型_使用python的概率模型进行公司估值

    python 概率分布模型 Note from Towards Data Science's editors: While we allow independent authors to publis ...

  4. 日常办公会用到的python模块-用 Python 自动化办公能做到哪些有趣或有用的事情?...

    所有需要重复做两次的事情,都可以用程序代替我来完成. 场景1: 微信上处理的事情有很多都是重复的,又经常容易被这些琐事打断.于是我在 Python 程序里设定了一些关键词和相应的自动回复: /> ...

  5. python自动化办公要学多久-用 Python 自动化办公能做到哪些有趣或有用的事情?...

    所有需要重复做两次的事情,都可以用程序代替我来完成. 场景1: 微信上处理的事情有很多都是重复的,又经常容易被这些琐事打断.于是我在 Python 程序里设定了一些关键词和相应的自动回复: /> ...

  6. 软考有很多70后的人,是什么原因会参加考试呢?

    软考证书有什么作用对自己有用就去考的吧~ 而且70后的也没有年纪很大,都还没到退休的年纪都还在工作,如果是在体制内工作的考个软考证还可以增加退休金工资,肯定是对工作有帮助或自己有用途才去考证. 1.软 ...

  7. 用python做自动化测试仪器_使用python进行windows自动化测试(1)

    最近开始学习整理python在windows自动化测试中的使用,觉得挺有意思的 主要思路,在windows下,主要通过启进程,然后查找进程的句柄,然后再操作这个句柄,包括点击,填写文字,关闭,获取文字 ...

  8. python卸载错误_卸载python后导致yum无法使用的解决办法 - Python - 服务器之家

    卸载python后导致yum无法使用的解决办法 发布时间:2014-08-03 来源:服务器之家 由于服务器需要升级python,参照了一篇坑爹的文章卸载了旧版python # 卸载旧的python ...

  9. python做副业_学习Python可以做哪些副业,你是不是感觉自己错过了一个亿?

    另外小编整理了一套Python的学习资料需要的按以下步骤可获得! 1.评论 2.转发 3.关注 4.后台私信[python]即可获取! 人生苦短,我用Python. 近年来,Python凭借其简洁易入 ...

  10. python培训班-Python培训机构_高品质Python线下开发培训班推荐-黑马程序员

    Python编程基础基础班1 课时:15天技术点:97项测验:2次学习方式:线下面授 学习目标 1.掌握Python开发环境基本配置|2.掌握运算符.表达式.流程控制语句.数组等的使用|3.掌握字符串 ...

最新文章

  1. Linux下屏蔽Ctrl+Alt+Delete
  2. 大势所趋,应用如何适配Android P HEIF图片格式
  3. Linux设备驱动模型概述(Linux device driver model overview)
  4. 中国计算机学会CCF推荐国际学术会议和期刊目录-计算机科学理论
  5. IDEA_Spring Data JPA有关报错Cannot resolve table 'XXX'
  6. 【算法设计与分析】Dijskra算法代码:Java版
  7. 搭建服务器Apache+PHP+MySql需要注意的问题
  8. 连接hadoop java.io.IOException:Could not locate executable null\bin\winutils.exe in the Hadoop binarie
  9. Dubbo 新编程模型之外部化配置 1
  10. 让你又爱又恨的推荐系统--程序猿篇
  11. html5音乐播放器格式midi,html5音频标签是否非正式地包含.mid(MIDI)?
  12. (已更新)婚礼类小程序前端界面模板源码
  13. CKA 报考指南与准备事项
  14. android(微博 微信 qq) 分享和第三分认证登录的封装
  15. 求两点连线与其中一点为球心球的交点——赋MATLAB代码
  16. roboone机器人_ROBOONE机器人这个品牌怎么样?是否可以加盟投资?
  17. MarkDown-如何插入上划线,下划线,中划线汇总
  18. java null转空_Java对象为空时,将null转换为 保存值为空的属性
  19. 【OpenCV入门学习--python】Anisotropic image segmentation by a gradient structure tensor
  20. 自己写了一个Asp.net探针的源码,希望大家讨论一下

热门文章

  1. Java识别图片扩展名(后缀名)
  2. python:基于itchat实现查找清理僵尸粉
  3. 基于MATLAB的高频信号设计,基于Matlab的语音信号滤波器的设计与实现
  4. dubbo解析-从dubbo协议分析如何设计RPC协议
  5. python就业前景和工资待遇怎么样
  6. 智能汽车安全研究:风险点、破解案例、研究工具
  7. 原生js模拟实现京东轮播图
  8. 公司员工信息纯HTML代码写表格table
  9. Linux 登陆与关机
  10. 共建“零碳未来”,顺丰凭得是什么?