Excel 的多进程使用,防止excel的误操作
来源:互联网 发布:怎么关闭网络禁用 编辑:程序博客网 时间:2024/05/20 08:24
程序通过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
- Excel 的多进程使用,防止excel的误操作
- 操作Excel时,只干掉当前Excel的进程
- 操作excel进程结束不了的方法
- excel的操作(生成Excel)
- C#使用Excel的COM组件操作Excel
- 【转载】Excel操作 Microsoft.Office.Interop.Excel.dll的使用
- 操作Excel的jxl包的使用
- C#操作Excel完成后进程上还存在Excel进程的问题
- 使用POI操作Excel的方法
- 使用Tcl操作Excel文件的方法
- java操作Excel及HSSFWorkbook的使用
- 使用ADO的方法操作EXCEL文件
- 使用Tcl操作Excel文件的方法
- BasicExcel 对Excel 的操作使用
- python 操作Excel openpyxl的使用
- 對excel的操作
- Excel的导出操作
- Excel的导出操作
- Java系列软件开发之我见(1未完待续)
- 介绍Windows的窗口、消息、子类化和超类化
- 最简单的全日制时间显示
- 用mysql触发器自动更新memcache
- C++中的inline
- Excel 的多进程使用,防止excel的误操作
- 数组初始化
- 不要依赖hibernate的二级缓存
- 学习COCOA “图片旋转”
- Window API函数大全
- Latex下添加新的宏包sty 目录 引用时出现问号
- Start porting kernel 2.6.27.8 to qq2440 (4) --Congratuation! Kernel boots OK!
- BCB 获取HTTP页面Data
- 为ASP封装的数据库操作类