python實現(xiàn)生成Word、docx文件的方法分析
本文實例講述了python實現(xiàn)生成Word、docx文件的方法。分享給大家供大家參考,具體如下:
http://python-docx.readthedocs.io/en/latest/index.html
生成word的利器!
一、快速開始
from docx import Document document = Document()
1、段落
加一個段落,下面paragraph 是前面內(nèi)容的光標(biāo)指向,后面再該處插入一句話。
paragraph = document.add_paragraph('Lorem ipsum dolor sit amet.') prior_paragraph = paragraph.insert_paragraph_before('Lorem ipsum')
后面加一句話
paragraph = document.add_paragraph('Lorem ipsum ') paragraph.add_run('dolor sit amet.')
添加段落風(fēng)格
document.add_paragraph('Lorem ipsum dolor sit amet.', style='ListBullet')
使用blod、italic 等等
paragraph = document.add_paragraph('Lorem ipsum ') run = paragraph.add_run('dolor') run.bold = True run.italic = True paragraph.add_run('dolor').bold = True
2、標(biāo)題
level表示標(biāo)題的大小
document.add_heading('The role of dolphins', level=2)
3、分頁
document.add_page_break()
4、表格
table = document.add_table(rows=2, cols=2)
訪問方法:
取出來,單獨賦值
cell = table.cell(0, 1) cell.text = 'parrot, possibly dead'
依然使用二維數(shù)組類似的索引。
row = table.rows[1] row.cells[0].text = 'Foo bar to you.' row.cells[1].text = 'And a hearty foo bar to you too sir!'
分清楚結(jié)構(gòu)
for row in table.rows: for cell in row.cells: print(cell.text)
查看信息
row_count = len(table.rows) col_count = len(table.columns)
添加一行
row = table.add_row()
動態(tài)添加表格
table = document.add_table(1, 3) # 標(biāo)題 heading_cells = table.rows[0].cells heading_cells[0].text = 'Qty' heading_cells[1].text = 'SKU' heading_cells[2].text = 'Description' # 添加內(nèi)容 for item in items: cells = table.add_row().cells cells[0].text = str(item.column1) cells[1].text = item.column2 cells[2].text = item.column3
5、添加圖片
from docx.shared import Inches document.add_picture('image-filename.png', width=Inches(1.25), height=Inches(1.25))
二、操作document
只能打開07之后的,會覆蓋。
document = Document('existing-document-file.docx') document.save('new-file-name.docx')
打開文件
f = open('foobar.docx', 'rb') document = Document(f) f.close() # or with open('foobar.docx', 'rb') as f: source_stream = StringIO(f.read()) document = Document(source_stream) source_stream.close() ... target_stream = StringIO() document.save(target_stream)
三、操作text
段落居中
from docx.enum.text import WD_ALIGN_PARAGRAPH document = Document() paragraph = document.add_paragraph() paragraph_format = paragraph.paragraph_format paragraph_format.alignment = WD_ALIGN_PARAGRAPH.CENTER
左邊整體縮進(jìn)
from docx.shared import Inches paragraph = document.add_paragraph() paragraph_format = paragraph.paragraph_format paragraph_format.left_indent = Inches(0.5)
右邊整體縮進(jìn)
from docx.shared import Pt paragraph_format.right_indent = Pt(24)
首行縮進(jìn)
paragraph_format.first_line_indent = Inches(-0.25)
從字體調(diào)節(jié),字體大小
run = document.add_paragraph().add_run() font = run.font from docx.shared import Pt font.size = Pt(10.5) # 5號字體 font.italic = True font.underline = True
字體顏色
from docx.shared import RGBColor font.color.rgb = RGBColor(0x42, 0x24, 0xE9)
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對大家Python程序設(shè)計有所幫助。
相關(guān)文章
python opencv實現(xiàn)圖片缺陷檢測(講解直方圖以及相關(guān)系數(shù)對比法)
這篇文章主要介紹了python opencv 圖片缺陷檢測,主要講解直方圖以及相關(guān)系數(shù)對比法,本文通過實例截圖給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-04-04解鎖Python并發(fā)編程中多線程與多進(jìn)程的應(yīng)用
本文我們將先從基本概念開始,然后通過詳細(xì)舉例探討每一種機(jī)制,特別關(guān)注多線程和多進(jìn)程的應(yīng)用,最后分享一些實戰(zhàn)經(jīng)驗以及一種優(yōu)雅的編程技巧,希望對大家有所幫助2023-05-05Python2 Selenium元素定位的實現(xiàn)(8種)
這篇文章主要介紹了Python2 Selenium元素定位的實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-02-02Python虛擬環(huán)境的創(chuàng)建和使用詳解
這篇文章主要給大家介紹了關(guān)于Python虛擬環(huán)境的創(chuàng)建和使用的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09ChatGPT教你用Python實現(xiàn)BinarySearchTree詳解
這篇文章主要為大家介紹了ChatGPT教你用Python實現(xiàn)BinarySearchTree詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02