天天看點

C#關閉excel程序方法

一直被一個問題困擾就是導出excel時如何關閉excel程序,我使用過oExcelApp.Quit(); 也用過GC回收,結果都不理想,後來發現可以kill程序,但是問題是kill程序 時不好解決多人并發的使用,比如一個人在導表然後kill是以的excel但是如果同時又有人在導表那麼這就把另外一個excel結束了,現在我們要辦的是如何kill目前這個程序,這裡我們先看一下代碼:

oExcelApp.Quit();

    oExcelApp = null;

    PublicMethod.Kill(oExcelApp);//調用kill目前excel程序

PublicMethod.Kill()内容是:

using System.Runtime.InteropServices;

 public class PublicMethod

 {

  public PublicMethod()

  {

   //

   // TODO: 在此處添加構造函數邏輯

   //

  }

  [DllImport("User32.dll",   CharSet   =   CharSet.Auto)]  

  public static extern int GetWindowThreadProcessId(IntPtr hwnd,out int ID);

  public static void Kill(Excel.Application excel)

  {  

   IntPtr t=new IntPtr(excel.Hwnd);   //得到這個句柄,具體作用是得到這塊記憶體入口 

  int k= 0;  

   GetWindowThreadProcessId(t,out k);   //得到本程序唯一标志k

   System.Diagnostics.Process p=System.Diagnostics.Process.GetProcessById(k);   //得到對程序k的引用

   p.Kill();     //關閉程序k

  }

}

這樣我們就可以關閉目前程序excel而不是殺掉所有的類型為excel程序了,

繼續閱讀