ICode9

精准搜索请尝试: 精确搜索
首页 > 系统相关> 文章详细

AutoHotkey使用Excel的Com对象可能导致进程残留问题的原因及解决方案

2019-03-26 12:44:03  阅读:287  来源: 互联网

标签:Target AutoHotkey xl Excel st Application 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
}

  

标签:Target,AutoHotkey,xl,Excel,st,Application,Com,函数
来源: https://www.cnblogs.com/hyaray/p/10599303.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有