使用Python docx修改word關(guān)鍵詞顏色的操作
需求:
在刷word題庫的時(shí)候,答案就在題目下方,干擾復(fù)習(xí)效果,將答案字體變成白色,查看答案的時(shí)候只需要將答案背景刷黑
轉(zhuǎn)換需求:
在word中找到關(guān)鍵字“答案”將其后面的信息改變顏色為白色
由于第一次使用 import docx,最初想按照如上思想實(shí)現(xiàn)比較麻煩,后整理思路,將題庫保存為txt,逐條讀取轉(zhuǎn)存入word,利用分割函數(shù)對(duì)關(guān)鍵字進(jìn)行分割,關(guān)鍵字后面的信息即為答案改變顏色,效果和需求一致,只是新建了文件
實(shí)現(xiàn)代碼:
import os import re import docx from docx.shared import RGBColor#設(shè)置字體 from docx import Document from docx.shared import Pt#設(shè)置字體 from docx.oxml.ns import qn#設(shè)置中文字體 f = open("test.txt","r")#將文檔和python放在一個(gè)目錄下無需復(fù)雜的路徑 i=0 document = Document()#新建word p = document.add_paragraph('')#新建段落,這句話放在循環(huán)外面可以減少空行 while i<3190: content = f.readline() #print(content) if content.find('答案')!=-1: #如果該行有關(guān)鍵字“答案”就以關(guān)鍵字為分界進(jìn)行分割 pt = r'(答案)' res = re.split(pt, content)#分割 #print(res[0],end=' ') #print(res[1],end=' ') #print(res[2]) #add_run在同一段添加內(nèi)容 run = p.add_run(res[0])#輸入關(guān)鍵字之前的字符 run.font.name=u'宋體' #設(shè)置插入的字體 run.font.size = Pt(15) r = run._element r.rPr.rFonts.set(qn('w:eastAsia'), u'宋體') run = p.add_run(res[1])#輸入關(guān)鍵字 run.font.name=u'宋體' #設(shè)置插入的字體 run.font.size = Pt(15) r = run._element r.rPr.rFonts.set(qn('w:eastAsia'), u'宋體') run = p.add_run(res[2])#輸入關(guān)鍵字之后的字符 run.font.name=u'宋體' #設(shè)置插入的字體 run.font.size = Pt(15) r = run._element r.rPr.rFonts.set(qn('w:eastAsia'), u'宋體') #設(shè)置關(guān)鍵字之后也就是答案的字體顏色,這里設(shè)置為白色 run.font.color.rgb = RGBColor(250,250,250) else: run = p.add_run(content)#如果該行沒有關(guān)鍵字“答案”則直接輸入word #print(content) run.font.name=u'宋體' #設(shè)置插入的字體 run.font.size = Pt(15) r = run._element r.rPr.rFonts.set(qn('w:eastAsia'), u'宋體') i+=1 document.save('路線1.docx')#關(guān)閉保存word f.close() #關(guān)閉TXT
需求本來挺簡單,由于初次使用DOCx,繞個(gè)小彎,做個(gè)記錄
補(bǔ)充:如果有多個(gè)關(guān)鍵字,可以用下面的代碼哦
for one_key in keys: if content.find(one_key) != -1: p = document.add_paragraph() pt = r'({})'.format(one_key) res = re.split(pt, content) for one_split in res: run = p.add_run(one_split) run.font.name = u'宋體' r = run._element r.rPr.rFonts.set(qn('w:eastAsia'), u'宋體') if one_split == one_key: run.font.color.rgb = RGBColor(220, 20, 60) run.font.bold = True break else: p = document.add_paragraph(u'{}'.format(content))
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
解讀調(diào)用jupyter?notebook文件內(nèi)的函數(shù)一種簡單方法
這篇文章主要介紹了解讀調(diào)用jupyter?notebook文件內(nèi)的函數(shù)一種簡單方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01Python實(shí)現(xiàn)簡單多線程任務(wù)隊(duì)列
本文給大家介紹的是使用很簡單的代碼實(shí)現(xiàn)的多線程任務(wù)隊(duì)列,給大家一個(gè)思路,希望對(duì)大家學(xué)習(xí)python能夠有所幫助2016-02-02python計(jì)算導(dǎo)數(shù)并繪圖的實(shí)例
今天小編就為大家分享一篇python計(jì)算導(dǎo)數(shù)并繪圖的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-02-02詳解將Pandas中的DataFrame類型轉(zhuǎn)換成Numpy中array類型的三種方法
這篇文章主要介紹了詳解將Pandas中的DataFrame類型轉(zhuǎn)換成Numpy中array類型的三種方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07Python利用正則表達(dá)式實(shí)現(xiàn)計(jì)算器算法思路解析
這篇文章主要介紹了Python利用正則表達(dá)式實(shí)現(xiàn)計(jì)算器算法思路解析,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧2018-04-04