Python實(shí)現(xiàn)將Excel內(nèi)容插入到Word模版中
前言
前段時(shí)間因?yàn)樾枰幚硪淮蠖羊?yàn)收單,都是一些簡(jiǎn)單的復(fù)制粘貼替換工作,于是就想到用python進(jìn)行處理。接下來(lái)進(jìn)入正題~
實(shí)現(xiàn)需求
我是用的開發(fā)環(huán)境是
- python 3.6
- openpyxl 3.1.1
- docx 0.2.4
需求

這個(gè)是從公司平臺(tái)導(dǎo)出的訂單詳情excel文件

這個(gè)是公司驗(yàn)收單模版
我這邊需求是把Excel文件中的訂單號(hào)、下單公司、套餐、數(shù)量分別添加到模版的訂單編號(hào)、甲方、驗(yàn)收測(cè)試內(nèi)容中,簡(jiǎn)單來(lái)說(shuō)就是通過(guò)python腳本,將excel文件的訂單號(hào)、下單公司、套餐、數(shù)量分別替換word文件中的OrderID、Company、Package、Quantity
實(shí)現(xiàn)代碼
明確需求后直接上代碼
import openpyxl
import docx
import datetime
def get_excel_data():
# 打開Excel文件
wb = openpyxl.load_workbook('下單明細(xì).xlsx')
ws = wb['Sheet1']
# 獲取序列號(hào)
for cell in ws['A']:
Number.append(cell.value)
# 獲取訂單號(hào)
for cell in ws['C']:
OrderID.append(cell.value)
# OrderID.pop(0)
# 獲取數(shù)量
for cell in ws['F']:
Quantity.append(cell.value)
# 獲取公司名稱
for cell in ws['B']:
Company.append(cell.value)
# 獲取訂單套餐
for cell in ws['D']:
Package.append(cell.value)
# 替換word文檔內(nèi)容
for i in range(len(Number)):
# 打開word文檔
new_doc = docx.Document('交付驗(yàn)收單.docx')
for p in new_doc.paragraphs:
for r in p.runs:
# print(r.text)
if 'OrderID' in r.text: # 替換訂單號(hào)
item = OrderID[i]
r.font.underline = True
r.text = r.text.replace('OrderID', item)
print('OrderID' + '更改為' + str(item))
if 'Quantity' in r.text: # 替換數(shù)量
item = Quantity[i]
r.font.underline = True
r.text = r.text.replace('Quantity', str(item))
print('Quantity' + '更改為' + str(item))
if 'Company' in r.text: # 替換公司名稱
item = Company[i]
r.font.underline = True
r.text = r.text.replace('Company', str(item))
print('Company' + '更改為' + str(item))
if 'Package' in r.text: # 替換訂單套餐
item = Package[i]
r.font.underline = True
r.text = r.text.replace('Package', str(item))
print('Package' + '更改為' + str(item))
# 替換日期 #這里因?yàn)榭梢灾苯痈哪0嫠凶⑨尩袅?,需要可開啟
# if 'Yy' in p.text:
# p.text = p.text.replace('Yy', str(year))
# if 'Mm' in p.text:
# p.text = p.text.replace('Mm', str(month))
# if 'Dd' in p.text:
# p.text = p.text.replace('Dd', str(day))
# 保存新文檔 #文件命名格式:交付驗(yàn)收單-公司名稱時(shí)間序號(hào).docx
new_doc.save('交付驗(yàn)收單-'+ str(Company[i]) +str(year)+str(month)+str(day)+'-' + str(Number[i]) + '.docx')
if __name__ == "__main__":
Number = []
OrderID = []
Quantity = []
Company = []
Package = []
now = datetime.datetime.now()
year = now.strftime("%Y")
month = now.strftime("%m")
day = now.strftime("%d")
get_excel_data()運(yùn)行效果
終端:

文件夾保存文件:

注意:這里我為了方便以及更直觀的看到效果,把Excel文件表頭欄也進(jìn)行替換了,后續(xù)如果需要可以使用
OrderID.pop(0)將表頭欄參數(shù)刪掉,再把for循環(huán)次數(shù)減一即可
for i in range(len(Number) - 1):替換后的word文件:

到此這篇關(guān)于Python實(shí)現(xiàn)將Excel內(nèi)容插入到Word模版中的文章就介紹到這了,更多相關(guān)Python Excel內(nèi)容插入到Word內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Pygame實(shí)戰(zhàn)練習(xí)之飛機(jī)大戰(zhàn)游戲
飛機(jī)大戰(zhàn)想必是很多人童年時(shí)期的經(jīng)典游戲,我們依舊能記得抱個(gè)老人機(jī)娛樂(lè)的場(chǎng)景,下面這篇文章主要給大家介紹了關(guān)于如何利用python寫一個(gè)簡(jiǎn)單的飛機(jī)大戰(zhàn)小游戲的相關(guān)資料,需要的朋友可以參考下2021-09-09
Python numpy多維數(shù)組實(shí)現(xiàn)原理詳解
這篇文章主要介紹了python numpy多維數(shù)組實(shí)現(xiàn)原理詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-03-03
python使用socket遠(yuǎn)程連接錯(cuò)誤處理方法
這篇文章主要介紹了python使用socket遠(yuǎn)程連接錯(cuò)誤處理方法,可有效的獲取Python中socket連接錯(cuò)誤處理的相關(guān)信息,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-04-04
python3實(shí)現(xiàn)猜數(shù)字游戲
這篇文章主要為大家詳細(xì)介紹了python3實(shí)現(xiàn)猜數(shù)字游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06
Python?encode()方法和decode()方法詳解
encode() 方法為字符串類型(str)提供的方法,用于將 str 類型轉(zhuǎn)換成 bytes 類型,這個(gè)過(guò)程也稱為“編碼”,這篇文章主要介紹了Python?encode()方法和decode()方法,需要的朋友可以參考下2022-12-12
Python中不可錯(cuò)過(guò)的五個(gè)超有用函數(shù)
在本文中,我們用代碼詳細(xì)說(shuō)明了Python中超實(shí)用的5個(gè)函數(shù)的重要作用,這些函數(shù)雖然簡(jiǎn)單,但卻是Python中功能最強(qiáng)大的函數(shù),下面一起來(lái)看看文章的詳細(xì)介紹吧,希望對(duì)你的學(xué)習(xí)有所幫助2022-01-01
Pandas之read_csv()讀取文件跳過(guò)報(bào)錯(cuò)行的解決
這篇文章主要介紹了Pandas之read_csv()讀取文件跳過(guò)報(bào)錯(cuò)行的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-04-04

