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