C#读取excel后不能关闭excel.exe

这篇博客探讨了在C#和ASP.NET中遇到的无法关闭Excel进程的问题。作者提出了一种结合释放资源和使用WinAPI(GetWindowThreadProcessId)来精确关闭Excel进程的解决方案,以避免依赖于不精确或不安全的方法。通过这种方式,可以确保100%成功关闭Excel.exe进程,同时避免使用GC.Collect以防止性能影响。
摘要由CSDN通过智能技术生成

http://www.cnblogs.com/wang_yb/archive/2010/05/02/1726135.html

http://blog.csdn.net/kable999/article/details/5057507

http://www.blogjava.net/tank414/archive/2006/11/04/excel.html



C#和Asp.net下excel进程一被打开,有时就无法关闭,   尤其是website.对关闭该进程有过GC、release等方法,但这些方法并不是在所有情况下均适用。  于是提出了kill   process的方法,   目前我见过的方法多是用进程创建时间筛选excel.exe进程,   然后kill 。     这样的方法是不精确的,   也是不安全的,   通过对网上一些关于Api运用文章的阅读,   我找到了更为直接精确找到这个process并kill的方法,以下就是代码        
using   System.Runtime.InteropServices;  
     
  [DllImport("User32.dll",   CharSet   =   CharSet.Auto)]  
  public   static   extern   int   GetWindowThreadProcessId(IntPtr   hwnd,   out   int   ID);  
  protected   void   Button1_Click(object   sender,   EventArgs   e)  
  {  
      Excel.ApplicationClass   excel   =   new   Microsoft.Office.Interop.Excel.ApplicationClass();  
      excel.Workbooks.Open("d:\aaa.xl

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值