结束Excel的进程的方法
2005-05-17 14:36
453 查看
转自:http://blog.csdn.net/ac669/archive/2005/01/22/263670.aspx
在论坛中经常看到问如何结束Excel进程的帖子,很多人给出
的方法是先得到系统进程列表,然后和“Excel”匹配,是Excel
的进程就杀死,我个人认为这个方法是不可行的,如果软件用这种方法
杀死自己启动的进程,应该算是Bug(有可能将用户Excel进程杀掉)。
我在网上找到了另一种杀死Excel 进程的方法,如下:
System.Runtime.InteropServices.Marshal.ReleaseComObject(worksheets);
System.Runtime.InteropServices.Marshal.ReleaseComObject(worksheet);
...
System.Runtime.InteropServices.Marshal.ReleaseComObject(excelApp);
System.Runtime.InteropServices.Marshal.ReleaseComObject(range);
worksheets=null;
worksheet=null;
...
excelApp=null;
range=null;
把操作Excel文件用到的对象实例全部释放。
然后资源回收!
GC.Collect();
以上的代码最好能放在finally中,防止操作Excel文件时发生异常而执行不到!
在打开任务管理器看看,excel进程是不是已经不在了!
哪位朋友如果有更好的方法,也请贡献出来,大家一起学习!
在论坛中经常看到问如何结束Excel进程的帖子,很多人给出
的方法是先得到系统进程列表,然后和“Excel”匹配,是Excel
的进程就杀死,我个人认为这个方法是不可行的,如果软件用这种方法
杀死自己启动的进程,应该算是Bug(有可能将用户Excel进程杀掉)。
我在网上找到了另一种杀死Excel 进程的方法,如下:
System.Runtime.InteropServices.Marshal.ReleaseComObject(worksheets);
System.Runtime.InteropServices.Marshal.ReleaseComObject(worksheet);
...
System.Runtime.InteropServices.Marshal.ReleaseComObject(excelApp);
System.Runtime.InteropServices.Marshal.ReleaseComObject(range);
worksheets=null;
worksheet=null;
...
excelApp=null;
range=null;
把操作Excel文件用到的对象实例全部释放。
然后资源回收!
GC.Collect();
以上的代码最好能放在finally中,防止操作Excel文件时发生异常而执行不到!
在打开任务管理器看看,excel进程是不是已经不在了!
哪位朋友如果有更好的方法,也请贡献出来,大家一起学习!
相关文章推荐
- 关于ASP.NET中调用Excel组件不能结束进程的解决方法
- [C#]结束Excel的进程的方法
- 关于ASP.NET中调用Excel组件不能结束进程的解决方法
- Excel.exe进程结束方法
- 关于 Excel 的结束进程的方法讨论
- 操作excel进程结束不了的方法
- ASP.NET调用Excel不能结束进程的解决方法
- [C#]结束Excel的进程的方法
- [C#]结束Excel的进程的方法
- Android下结束进程的方法
- 用VB结束Excel的进程
- C#关闭excel进程方法
- 关于ASP.NET MVC中Response.Redirect和RedirectToAction的BUG (跳转后继续执行后面代码而不结束进程)以及处理方法
- 批处理-获取启动项及结束进程使用方法(摘录)
- Android下结束进程的方法
- XP/WIN7系统中删除已结束进程托盘图标的方法
- .NET(C#):谈谈各种结束进程的方法
- c#关闭excel进程失败的解决方法
- 【转自Mgen】 .NET(C#):谈谈各种结束进程的方法
- 强制结束linux系统下的tomcat进程及tomcat重启的方法