大家好,我是Python進階者。
一、前言
前幾天在幫助粉絲解決問題的時候,遇到一個簡單的小需求,這里拿出來跟大家一起分享,后面再次遇到的時候,可以從這里得到靈感。
二、需求澄清
粉絲的問題來源于實際的需求,下圖是原始數(shù)據(jù),需要在1-3處填充另外一個表格中的數(shù)據(jù):

如果是正常操作的話,肯定是點擊進去Excel文件,然后每個單元格進行復制,然后粘貼到新文件,然后保存,之后重命名。
這樣做肯定是可以,但是當有上百個文件夾需要復制呢?上千個文件呢?肯定就需要消耗大量的時間和精力了。估計一天都不一定完成的了。
這里使用Python進行批量實現(xiàn)!
三、實現(xiàn)過程
這里給大家提供一個可行的代碼,思路也很簡單,openpyxl庫進行實現(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) # 編號
workbook2 = openpyxl.load_workbook("訂單.xlsx")
worksheet2 = workbook2[0]
print(worksheet2['C3'].value) # 城市
print(worksheet2['D3'].value) # 編號
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}處理完成")
代碼運行之后,就可以實現(xiàn)該Excel文件中對應的數(shù)據(jù)替換了。不過這里只是單個文件的替換。
如果想要批量的進行替換的話,則需要加入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é)
大家好,我是皮皮。這篇文章主要盤點一個Python自動化辦公的實用案例,這個案例可以適用于實際工作中文件處理,大家也可以稍微改進下,用于自己的實際工作中去,舉一反三。通過這個案例,大家應該學習到了很多,我相信應該還有其他更好的方法,歡迎大家留言區(qū)留言。