AutoHotkey使用Excel的Com对象可能导致进程残留问题的原因及解决方案
Posted hyaray
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了AutoHotkey使用Excel的Com对象可能导致进程残留问题的原因及解决方案相关的知识,希望对你有一定的参考价值。
在AutoHotkey脚本中,对Excel的应用体验很不错,xl := ComObjActive("Excel.Application")就和当前Excel表连接了,
通过xl变量就能调用VBA代码操作Excel,也能监视Excel事件,这种事件能对所有工作表都能效,通用性很好。
本人就是因为偷懒,声明了Global xl,这样在任何函数内都能直接使用,非常方便,
否则要么是每个函数都需要多传入xl参数,或者每个函数声明为Global,这样也能使用外面的变量,都不太理想。
直到近期,才发现声明全局变量后,如果使用完没有释放xl,会导致Excel进程残留。
解决方案:
- 继续使用全局变量xl,每次使用后释放xl。
- 规范代码,每个函数都增加一个参数xl。
- 把Excel的函数都写到Class内,每个函数都通过This.xl调用。
附上AutoHotkey监控Excel工作表事件代码
st := ComObjActive("Excel.Application").Activesheet ;工作表必须赋值到变量 ComObjConnect(st, "st_") Return st_SelectionChange(Target) { ;事件函数内获取Application可用 Target.Worksheet.Application ToolTip,% Target.Address }
以上是关于AutoHotkey使用Excel的Com对象可能导致进程残留问题的原因及解决方案的主要内容,如果未能解决你的问题,请参考以下文章
AutoHotkey监控Excel事件应用---根据当前列的值高亮行
autohotkey excel getfullname (ComObjActive)