最近考試系統(tǒng)項目來了一個需求衰絮,需要根據(jù)給出的模板疼鸟,直接在后臺批量輸出試卷的word docx文檔
于是看了看網(wǎng)上的包 找到了:python-docx
官方文檔那叫一個難讀啊··(英語廢)
所以把重要的功能總結(jié)一下
安裝:python3 :pip install python-docx
text的font,size沉馆,大小,顏色的設(shè)置
先說一下這個api中對于一個docx的組織情況
一個word文檔,分為標(biāo)題heading和paragraph等塊級元素
paragraph 內(nèi)部根據(jù)不同的文字格式泽艘,不同的字體,甚至不同的字體大小镐依,粗體匹涮,斜體 劃分為一個個的內(nèi)聯(lián)塊(也就是后面說的 run )
這句話非常重要,這決定了之后想要編輯段落文字的所有格式槐壳,每一個不同格式都要添加一次run
可以說然低,不論你想要在docx中添加什么東西,這個東西都是封裝在 run 這個最小單位內(nèi)部的务唐,它的格式雳攘,必須通過操作 run 來改變
舉個栗子:以下為一個段落paragraph:
這是一個run,這是一個run枫笛,這也是一個run吨灭,
這還是一個run
和我們使用word不同,我們必須先添加一個run刑巧,并且賦給它一小段文字喧兄,然后再通過run的api來改變它的格式
實例:我們想要添加一個段落,并且把這段文字的字體的一部分設(shè)置為宋體 另外一部分設(shè)置為微軟雅黑并且將文字設(shè)置為11磅啊楚,黑色
from docx import Document
from docx.enum.text import WD_ALIGN_PARAGRAPH,WD_LINE_SPACING
from docx.shared import Pt
from docx.shared import RGBColor
from docx.shared import Inches
doc = Document() #生成一個空的docx對象
doc.add_heading() #添加標(biāo)題
p = doc.add_paragragh() #添加段落
run=p.add_run('這段文字是宋體吠冤,')
run.font.name = u'宋體'
run._element.rPr.rFonts.set(qn('w:eastAsia'), u'宋體')
run=p.add_run('這段文字是微軟雅黑')
run._element.rPr.rFonts.set(qn('w:eastAsia'), u'微軟雅黑')
run.font.size = Pt(11) #設(shè)置大小為11磅
run.font.color.rgb = RGBColor(0,0,0)#設(shè)置顏色為黑色
document.save('demo.docx')#保存到demo.docx,默認(rèn)為工程目錄下
效果:
添加圖片
實際上特幔,圖片在docx中也被認(rèn)為是一個run咨演,和一段文字是一樣看待的
所以插入圖片也要先插入一個run,再設(shè)置run的內(nèi)容為 picture
p = document.add_paragraph()
run = p.add_run()
run.add_picture(img.jpg)
另外蚯斯,python-docx目前只能支持插入內(nèi)聯(lián)圖片薄风,沒有辦法插入https://exam-test.cecctm.com/media/images/detect/1111111.png
鏈接,關(guān)于內(nèi)聯(lián)圖片拍嵌,是指的存在本機的圖片嗎遭赂,而不是存在互聯(lián)網(wǎng)上的圖片,有懂得dalao求解答一下——
設(shè)置頁面段落排版等
和上面不同横辆,頁面段落的排版撇他,是在塊級元素上進行操作的,
也就是需要對paragraph,heading等對象進行修改困肩,但是如果牽扯到塊級元素內(nèi)部文字的大小划纽,顏色等等,則仍然需要add_run(陰魂不散靶炕)
上面這段話聽不懂沒關(guān)系勇劣,看下例子
如果你想添加一個字體大小為24磅的標(biāo)題,并且居中
假如你這樣的話
from docx.enum.text import WD_ALIGN_PARAGRAPH,WD_LINE_SPACING
head = document.add_heading('這是標(biāo)題'潭枣,level=1)#添加一級標(biāo)題
head.alignment = WD_ALIGN_PARAGRAPH.CENTER#居中
你會發(fā)現(xiàn)比默,你沒法把heading的文字"這是標(biāo)題"四個字變?yōu)?4磅了!因為你沒有在heading里面添加run盆犁,如果你希望把它變?yōu)?4磅命咐,你必須這樣:
from docx.enum.text import WD_ALIGN_PARAGRAPH,WD_LINE_SPACING
head = document.add_heading('level=1')#添加一級標(biāo)題
run = head.add_run('這是標(biāo)題')
run.font.size = Pt(24)
head.alignment = WD_ALIGN_PARAGRAPH.CENTER#居中
總之,是不能把文字直接放在高級塊中的···不然是沒有辦法編輯的谐岁!
用戶下載docx
output = '/main/media/paper_docx.docx'
resp = make_response(send_file(output))
響應(yīng)為下載