在ExecuteExcel4Macro
Python 中运行 Excel 宏时,我总是得到 False 结果,这是执行的代码:
import win32com.client
filename = r'E:\excel.xls'
xlApp = win32com.client.Dispatch('Excel.Application')
xlApp.visible = 1
xlBook = xlApp.Workbooks.Open(filename)
strPara = xlBook.Name + '!Macro1()'
res = xlApp.ExecuteExcel4Macro(strPara)
print res
xlBook.Close(SaveChanges=0)
“print res”语句的输出是:False
在我搜索MSDNExecuteExcel4Macro
上的用法后,我得到以下信息:
ExecuteExcel4Macro -- 运行 Microsoft Excel 4.0 宏函数,然后返回函数的结果。返回类型取决于函数。
然后我就糊涂了:既然Excel中的宏总是一个“子程序”,而VBA中的“子程序”没有返回结果,那么Excel宏怎么能返回结果呢?那么上例中的 False 结果代表什么?
之后,我ExecuteExcel4Macro
在 Excel(2003) 中尝试使用 VBA 而非 Python 进行编码:
Sub RunMacro()
res = ExecuteExcel4Macro("excel.xls!Macro1()")
MsgBox CStr(res)
End Sub
Sub Macro1()
MsgBox "in Macro1"
End Sub
并且显示的“res”字符串MsgBox
是相同的:False
1.为什么返回结果ExecuteExcel4Macro
总是False?
2.如果我想在Python中运行Excel宏并获取Excel宏函数的退出状态怎么办?
2011.10.28 更新:
Sub TEST()
res = Application.Run(MacroToRun)
MsgBox CStr(res)
End Sub
Function MacroToRun()
MacroToRun = True
End Function
在 Excel 2003 中运行 TEST Macro 后,我得到以下信息:
包含“错误 2015”信息的对话框。