Excel 的多进程使用,防止excel的误操作

    程序通过ExcelApplication创建了一个隐藏的EXCEL进程并打开了一个内部excel文件进行操作,可是,在程序运行期间,如果用户再启动一个excel或者打开一个excel文件,则我隐藏的excel文件则被显示出来,数据彻底暴露,而且当excel被显示事件用户的操作可能导致Excel操作的异常,甚至用户可能关闭Excel导致操作无法继续
    整个问题困扰了好长时间,终于找到解决方案:
    解决方法:通过创建一个额外的Excel进程来保护真实使用的进程,使用户在打开Excel时使用该保护进程来进行操作,从而防止对正常进程的误操作
   
    1.声明       
    '程序所要使用的进程
    Private xlApp As Excel.Application
    '保护进程(用户要使用的进程)   
    Private xlAppProtect As Excel.Application                   
    2.初始化
    Set xlApp = CreateObject("Excel.Application")
    ’
先初始化程序要用的进程,因为用户在双击打开文档时间所调用的进程是最后创建的进程(即xlAppProtect
    Set xlAppProtect = CreateObject("Excel.Application")

    3.运行   

    4.释放
  
xlApp.Quit
    If xlAppProtect.Workbooks.Count = 0 Then
        '保护进程可不能随便退出,用户可能正在使用       
        xlAppProtect.Quit
    End If
    Set xlApp = Nothing
    Set xlAppProtect = Nothing


   

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值