Python操作word文檔的示例詳解
寫在前面
python-docx 不支持 doc 文檔,一定要注意該點(diǎn),如果使用 doc 文檔,需要提前將其用 Word 相關(guān)軟件轉(zhuǎn)換為 docx 格式。 doc 和 docx 是存在本質(zhì)差異的,一個(gè)是二進(jìn)制,另一個(gè) XML 格式的文件。
模塊的安裝 pip install python-docx 。
以下網(wǎng)址首先準(zhǔn)備好
- 官方手冊(cè):https://python-docx.readthedocs.io/en/latest/index.html
- pypi 官方地址:https://pypi.org/project/python-docx/
資料準(zhǔn)備完畢,即可進(jìn)入編碼環(huán)節(jié)。
創(chuàng)建一個(gè)文檔
第一個(gè)需求,創(chuàng)建一個(gè)文檔,并在里面寫入各種信息。
先實(shí)現(xiàn)第一步,寫入一個(gè)標(biāo)題
注意下文中的 add_heading() 函數(shù)的用法。
from docx import Document
# 創(chuàng)建 Document 對(duì)象,等價(jià)于在電腦上打開一個(gè) Word 文檔
document = Document()
# 在 Word 文檔中添加一個(gè)標(biāo)題
document.add_heading('這是一個(gè)標(biāo)題',level=0)
# 保存文檔
document.save('demo.docx')添加文字段落
注意下文中 add_paragraph() 函數(shù)添加段落,使用 add_run() 追加文本
from docx import Document
# 創(chuàng)建 Document 對(duì)象,等價(jià)于在電腦上打開一個(gè) Word 文檔
document = Document()
# 在 Word 文檔中添加一個(gè)標(biāo)題
document.add_heading('這是一個(gè)標(biāo)題', level=0)
# 文檔添加段落
p = document.add_paragraph('這是白給的段落')
# 添加帶樣式的文字
# 添加段落,文本可以包含制表符(\t)、換行符(\n)或回車符(\r)等
# add_run() 在段落后面追加文本
p.add_run('\n我傾斜了').italic = True # 添加一個(gè)傾斜文字
p.add_run('\n我加粗了').bold = True # 添加一個(gè)加粗文字
# 保存文檔
document.save('demo.docx')在段落前面增加文字
p.add_run('\n我傾斜了').italic = True # 添加一個(gè)傾斜文字
p.add_run('\n我加粗了').bold = True # 添加一個(gè)加粗文字
# 段落前面插入內(nèi)容
prep_p = p.insert_paragraph_before('段落之前插入內(nèi)容')段落還可以添加分頁(yè)符,代碼如下所示:
# 段落前面插入內(nèi)容
prep_p = p.insert_paragraph_before('段落之前插入內(nèi)容')
document.add_page_break()
p1 = document.add_paragraph('新頁(yè)新段落')
列表的添加
無(wú)序列表的添加
# 添加列表(前面一個(gè)小圓點(diǎn))
document.add_paragraph('我前面是小圓點(diǎn)', style='List Bullet')
# 添加列表(前面一個(gè)小圓點(diǎn))
document.add_paragraph('第二個(gè)小圓點(diǎn)', style='List Bullet')有序列表的添加
# 添加列表(前面數(shù)字)
document.add_paragraph('我前面是數(shù)字', style='List Number')
# 添加列表(前面數(shù)字)
document.add_paragraph('第二個(gè)數(shù)字', style='List Number')圖片的添加
Document 對(duì)象具備的方法如下所示:
add_heading(self, text='', level=1):添加標(biāo)題;add_page_break(self):分頁(yè)符;add_paragraph(self, text='', style=None):添加段落;add_picture(self, image_path_or_stream, width=None, height=None):添加圖片;add_section(self, start_type=2):添加節(jié);add_table(self, rows, cols, style=None):添加表格;
本部分重點(diǎn)學(xué)習(xí) add_picture() 方法。
document.add_picture(r"../9.png", width=Inches(1))
add_picture() 函數(shù)中參數(shù) image_path_or_stream 可以為相對(duì)地址或者絕對(duì)地址,也可以是一個(gè)圖片數(shù)據(jù)流,上述代碼中 Inches 表示英寸,除此之外, python-docx 還提供了厘米 (Cm) ,如設(shè)置 1厘米: Cm(1) ,使用的時(shí)候需要提前導(dǎo)入 from docx.shared import Inches, Cm 。
表格添加
使用 add_table() 函數(shù),可以在 Word 文檔中添加表格。
p1 = document.add_paragraph('新頁(yè)新段落')
# 添加一個(gè) 2×2 表格
table = document.add_table(rows=2, cols=2)
# 獲取第1行第2列單元格
cell = table.cell(0, 1)
# 設(shè)置單元格文本
cell.text = '第1行第2列'
# 獲取第2行
row = table.rows[1]
row.cells[0].text = '橡皮擦'
row.cells[1].text = '喬喻'學(xué)習(xí)的時(shí)候注意一下相關(guān)注釋,即可掌握該部分內(nèi)容。
相關(guān)樣式設(shè)置
設(shè)置格式需要用 add_run() ,直接使用 add_paragraph() 生成的段落不能直接設(shè)置字體等樣式。
# 模塊的導(dǎo)入
from docx.shared import Pt, Cm, Inches
from docx.oxml.ns import qn
from docx.enum.text import WD_ALIGN_PARAGRAPH
from docx.shared import RGBColor
# 一級(jí)標(biāo)題 level=0
head0 = document.add_heading(level=0)
# 標(biāo)題居中
head0.alignment = WD_ALIGN_PARAGRAPH.CENTER
title_run = head0.add_run('這是一個(gè)居中的標(biāo)題', )
title_run.font.size = Pt(24)
# 標(biāo)題英文字體
title_run.font.name = 'Times New Roman'
# 標(biāo)題中文字體
title_run.element.rPr.rFonts.set(qn('w:eastAsia'), '微軟雅黑')
# 字體顏色
title_run.font.color.rgb = RGBColor(4, 60, 169)其中 WD_ALIGN_PARAGRAPH 對(duì)象表示段落對(duì)其的方式,其值包括如下內(nèi)容
WD_ALIGN_PARAGRAPH. LEFT:左對(duì)齊;WD_ALIGN_PARAGRAPH. CENTER:居中對(duì)其;WD_ALIGN_PARAGRAPH. RIGHT:右對(duì)齊;WD_ALIGN_PARAGRAPH. JUSTIFY:兩端對(duì)齊;
行距,段間距 line_spacing 屬性用來(lái)設(shè)置行距, space_before 表示段前距, space_after 表示段后距。
斜體,下劃線,粗體設(shè)置
font.italic = True #設(shè)置斜體 font.underline = True #設(shè)置下劃線 font.bold = True #設(shè)置粗體
首行縮進(jìn) paragraph_format_line_indent 可以設(shè)置縮進(jìn)值。
其它設(shè)置 除了上述內(nèi)容外,還可以通過(guò) document.styles.add_style('textstyle', WD_STYLE_TYPE. PARAGRAPH) ,使用 add_style() 方法創(chuàng)建新的樣式對(duì)象,后續(xù)就可以通過(guò)提供的屬性進(jìn)行樣式設(shè)置,設(shè)置字體使用 font.size ,設(shè)置字體顏色為 font.color 。
然后在添加段落的時(shí)候,就可以應(yīng)用該屬性了。
from docx.shared import RGBColor
from docx.enum.style import WD_STYLE_TYPE
style = document.styles.add_style('textstyle', WD_STYLE_TYPE.PARAGRAPH)
# 字體大小
style.font.size = Pt(16)
# 字體顏色
style.font.color.rgb = RGBColor(66, 100, 0)
p1 = document.add_paragraph('神人橡皮擦',style=style)頁(yè)眉和頁(yè)腳
頁(yè)眉和頁(yè)腳可以直接設(shè)置,參考代碼如下所示
header = document.sections[0].header
header.add_paragraph('橡皮擦的頁(yè)眉')頁(yè)腳設(shè)置
footer = document.sections[0].footer
到此這篇關(guān)于Python操作word文檔的示例詳解的文章就介紹到這了,更多相關(guān)Python操作word文檔內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
從頭學(xué)Python之編寫可執(zhí)行的.py文件
這篇文章主要介紹了從頭學(xué)Python之編寫可執(zhí)行的.py文件,具有一定參考價(jià)值,需要的朋友可以了解下。2017-11-11
python之如何使用openpyxl設(shè)置單元格樣式
這篇文章主要介紹了python之如何使用openpyxl設(shè)置單元格樣式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06
對(duì)python中的six.moves模塊的下載函數(shù)urlretrieve詳解
今天小編就為大家分享一篇對(duì)python中的six.moves模塊的下載函數(shù)urlretrieve詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-12-12
Pandas數(shù)據(jù)操作分析基本常用的15個(gè)代碼片段
這篇文章主要介紹了Pandas數(shù)據(jù)操作分析基本常用的15個(gè)代碼片段,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09
python3 requests庫(kù)文件上傳與下載實(shí)現(xiàn)詳解
這篇文章主要介紹了python3 requests庫(kù)文件上傳與下載實(shí)現(xiàn)詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08
Python3實(shí)現(xiàn)的回文數(shù)判斷及羅馬數(shù)字轉(zhuǎn)整數(shù)算法示例
這篇文章主要介紹了Python3實(shí)現(xiàn)的回文數(shù)判斷及羅馬數(shù)字轉(zhuǎn)整數(shù)算法,涉及Python數(shù)值運(yùn)算、轉(zhuǎn)換等相關(guān)操作技巧,需要的朋友可以參考下2019-03-03

