是否可以使用Python将工作表插入现有工作簿?

时间:2016-01-22 11:17:30

标签: pandas xlrd xlwt

问题 使用Pandas和Python创建精美的报告。

建议的解决方案 使用包含模板表的模板xlsx文件,使用对另一个预先填充的工作表的引用进行格式化,删除预先填充的表并从pandas插入新的工作表。模板表将丢失恢复为#REF的链接,因此需要重命名这些链接。

我试过了:

import os
import xlrd, xlwt 
import envconfig


swb1 = xlrd.open_workbook(os.path.join(envconfig.REPORT_WRITER_PATH,'TEMPLATE.xls'), on_demand=True, formatting_info=True) 
swb2 = xlrd.open_workbook(os.path.join(envconfig.REPORT_WRITER_PATH,'REPORT.xls'), on_demand=True, formatting_info=True) 
swb1s1 = swb1.sheet_by_name('Template')
swb2s1 = swb2.sheet_by_name('Report')

twb = xlwt.Workbook() 
sheet1 = twb.add_sheet(swb1s1)
sheet2 = twb.add_sheet(swb2s1)
twb.save("python_spreadsheet.xls")

以上错误:

  sheet1 = twb.add_sheet(swb1s1)
  File "C:\Users\pa003202\AppData\Local\Continuum\Anaconda3\lib\site-packages\xlwt\Workbook.py", line 366, in add_sheet
  sheetname = sheetname.decode(self.encoding)
AttributeError: 'Sheet' object has no attribute 'decode'
  sheetname = sheetname.decode(self.encoding)
AttributeError: 'Sheet' object has no attribute 'decode'

有没有办法将pandas中的数据注入工作簿或打开工作簿并插入工作表?

1 个答案:

答案 0 :(得分:3)

我通过创建描述的模板解决了这个问题,并在此处使用了解决方案:

建议的解决方案使用包含模板工作表的模板xlsx文件,使用对另一个预先填充的工作表的引用进行格式化,从pandas插入新的工作表。如果插入的工作表具有相同的名称,模板工作表不会丢失链接。

<强>解决方案

查看How to write to an existing excel file without overwriting data?,这适用于该方案。