=====求助!ASP.NET如何在Windows2003下释放Excel进程=====

SuperMicrosoft 2005-06-10 11:25:23
小妹在利用ASP.NET作Excel文件导入、导出,在WindowsXP下成功完成,但移植到Windows2003时发现进程没有被收集,而是调用一次新建一次,不只如何关掉没用Excel的进程或将其收集清理,我现在的代码是:
m_objExApp.Quit()
ReleaseComObject(m_objSheet)
ReleaseComObject(m_objWorkbook)
ReleaseComObject(m_objExApp)
m_objRange = Nothing
m_objSheet = Nothing
m_objWorkbook = Nothing
m_objExApp = Nothing
System.GC.Collect()
...全文
54 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
jamex 2005-09-07
  • 打赏
  • 举报
回复
在论坛中经常看到问如何结束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进程是不是已经不在了!


kalakala 2005-07-19
  • 打赏
  • 举报
回复
myProcesses = Process.GetProcessesByName("EXCEL")
For Each myProcess In myProcesses
myProcess.Kill()

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧