我正在尝试将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
获取了代码更新了有效的代码
答案 0 :(得分:0)
ActiveSheet
是一个字段,就像你在这里使用它一样:
cht = excel.ActiveSheet.ChartObjects().Add(0,0,xl_range.Width, xl_range.Height)
或者像你在这里使用它的方法:
excel.ActiveSheet().Delete()
由于第一次调用没有给你错误,并且错误显示找不到该成员,我猜测第二次调用是错误的,应该是:
excel.ActiveSheet.Delete()