如何将来自不同文件的多个Excel工作表合并为一个文件

时间:2014-02-06 23:54:40

标签: python excel win32com

每个源文件只包含一个工作表。我想要的是将这些表合并到一个文件中。我想我必须使用win32com。

有谁知道怎么做?

更新:要合并的工作表有广泛的条件格式,我想保留。以下代码只能将它们与丢失的所有有条件格式信息组合在一起。

from openpyxl import load_workbook, Workbook
import os

fwb = Workbook()

wb = load_workbook('CM1.xlsx')
ws1 = wb.active
wb = load_workbook('CM2.xlsx')
ws2 = wb.active
wb = load_workbook('CM3.xlsx')
ws3 = wb.active

fwb.add_sheet(ws1)
fwb.add_sheet(ws2)
fwb.add_sheet(ws3)

fwb.save('CM.xlsx')

2 个答案:

答案 0 :(得分:2)

谢谢你们俩!在听完你的建议并尝试了5分钟之后,以下工作了!

import win32com.client as win32
import os

excel = win32.gencache.EnsureDispatch('Excel.Application')
wb = excel.Workbooks.Add()

for f in [os.path.join(os.getcwd(), "CM1.xlsx"), os.path.join(os.getcwd(), "CM2.xlsx")]: 
    w = excel.Workbooks.Open(f) 
    w.Sheets(1).Copy(wb.Sheets(1))

wb.SaveAs(os.path.join(os.getcwd(), "CM.xlsx"))
excel.Application.Quit()

答案 1 :(得分:0)

这会将工作表1 ot to_copy粘贴到emptyWorkbook的工作表1

empty_wb = xl.Workbooks.Open(util.getTestRessourcePath("emptyWorkbook.xlsx"))
tocopy_wb = xl.Workbooks.Open(util.getTestRessourcePath("toCopy.xls"))

tocopy_wb.Sheets(1).Cells.Copy()
empty_wb.Sheets(1).Paste(empty_wb.Sheets(1).Range("A1"))