使用python导出后删除Excel工作表时出错

时间:2016-06-05 09:19:28

标签: python windows excel winapi win32com

我正在尝试将Excel中的图表保存为Python中的图像文件。我正在使用WIn32com,图表将根据需要导出,但是当我尝试删除ActiveSheet时,它会给我错误。

excel.ActiveSheet().Delete()
  File "C:\Python27\lib\site-packages\win32com\client\dynamic.py", line 192, in __call__
    return self._get_good_object_(self._oleobj_.Invoke(*allArgs),self._olerepr_.defaultDispatchName,None)
pywintypes.com_error: (-2147352573, 'Member not found.', None, None)

有什么帮助可以克服这个错误吗?

以下是我的代码:

import win32com.client as win32

def saveChart():
    excel = win32.Dispatch("Excel.Application")
    wb = excel.Workbooks.Open(r'C:\Users\projects\Rating.xlsx')
    selection = "A1:K16"
    xl_range = wb.Sheets("Categories").Range(selection)
    excel.ActiveWorkbook.Sheets.Add().Name="image_sheet"
    cht = excel.ActiveSheet.ChartObjects().Add(0,0,xl_range.Width, xl_range.Height)
    xl_range.CopyPicture()
    cht.Chart.Paste()
    cht.Chart.Export(r'C:\Users\projects\MyExportedChart.png')
    excel.DisplayAlerts = False
    cht.Delete()
    excel.ActiveSheet.Delete()

    excel.DisplayAlerts = True
    excel.ActiveWorkbook.Close()

我从Export Charts from Excel as images using Python

获取了代码

更新了有效的代码

1 个答案:

答案 0 :(得分:0)

ActiveSheet是一个字段,就像你在这里使用它一样:

cht = excel.ActiveSheet.ChartObjects().Add(0,0,xl_range.Width, xl_range.Height)

或者像你在这里使用它的方法:

excel.ActiveSheet().Delete()

由于第一次调用没有给你错误,并且错误显示找不到该成员,我猜测第二次调用是错误的,应该是:

excel.ActiveSheet.Delete()