如果是正常操作的話,肯定是點(diǎn)擊進(jìn)去Excel文件,然后每個(gè)單元格進(jìn)行復(fù)制,然后粘貼到新文件,然后保存,之后重命名。
大家好,我是Python進(jìn)階者。
一、前言
前幾天在幫助粉絲解決問(wèn)題的時(shí)候,遇到一個(gè)簡(jiǎn)單的小需求,這里拿出來(lái)跟大家一起分享,后面再次遇到的時(shí)候,可以從這里得到靈感。
二、需求澄清
粉絲的問(wèn)題來(lái)源于實(shí)際的需求,下圖是原始數(shù)據(jù),需要在1-3處填充另外一個(gè)表格中的數(shù)據(jù):

如果是正常操作的話,肯定是點(diǎn)擊進(jìn)去Excel文件,然后每個(gè)單元格進(jìn)行復(fù)制,然后粘貼到新文件,然后保存,之后重命名。
這樣做肯定是可以,但是當(dāng)有上百個(gè)文件夾需要復(fù)制呢?上千個(gè)文件呢?肯定就需要消耗大量的時(shí)間和精力了。估計(jì)一天都不一定完成的了。
這里使用Python進(jìn)行批量實(shí)現(xiàn)!
三、實(shí)現(xiàn)過(guò)程
這里給大家提供一個(gè)可行的代碼,思路也很簡(jiǎn)單,openpyxl庫(kù)進(jìn)行實(shí)現(xiàn),代碼如下:
import openpyxl
workbook1 = openpyxl.load_workbook("模板.xlsx")
worksheet1 = workbook1.worksheets[0]
print(worksheet1['C4'].value) # 金額
print(worksheet1['D4'].value) # 公司
print(worksheet1['F4'].value) # 編號(hào)
workbook2 = openpyxl.load_workbook("訂單.xlsx")
worksheet2 = workbook2[0]
print(worksheet2['C3'].value) # 城市
print(worksheet2['D3'].value) # 編號(hào)
print(worksheet2['CU3'].value) # 金額
print(worksheet2['DM3'].value) # 公司
print(f"正在處理訂單:{worksheet2['C3'].value}...")
worksheet1['C4'].value = worksheet2['CU3'].value
worksheet1['D4'].value = f"{worksheet2['DM3'].value}分公司"
worksheet1['F4'].value = worksheet2['D3'].value
new_file_name = f"({worksheet2['C3'].value} {worksheet2['D3'].value})"
workbook1.save(new_file_name + '.xlsx')
print(f"訂單:{worksheet2['C3'].value}處理完成")
代碼運(yùn)行之后,就可以實(shí)現(xiàn)該Excel文件中對(duì)應(yīng)的數(shù)據(jù)替換了。不過(guò)這里只是單個(gè)文件的替換。
如果想要批量的進(jìn)行替換的話,則需要加入for循環(huán),如下所示:
for i in range(len(worksheet.row)):
print(f"正在第{i}行,處理訂單:{worksheet2[f'C{i}'].value}...")
worksheet1['C4'].value = worksheet2[f'CU{i}'].value
worksheet1['D4'].value = f"{worksheet2[f'DM{i}'].value}分公司"
worksheet1['F4'].value = worksheet2[f'D{i}'].value
new_file_name = f"({worksheet2[f'C{i}'].value} {worksheet2[f'D{i}'].value})"
workbook1.save(new_file_name + '.xlsx')
time.sleep(3)
print(f"訂單:{worksheet2[f'C{i}'].value}處理完成")
三、總結(jié)
大家好,我是皮皮。這篇文章主要盤(pán)點(diǎn)一個(gè)Python自動(dòng)化辦公的實(shí)用案例,這個(gè)案例可以適用于實(shí)際工作中文件處理,大家也可以稍微改進(jìn)下,用于自己的實(shí)際工作中去,舉一反三。通過(guò)這個(gè)案例,大家應(yīng)該學(xué)習(xí)到了很多,我相信應(yīng)該還有其他更好的方法,歡迎大家留言區(qū)留言。