c#EXCEL關閉(關閉EXCEL進程)

來源:互聯網
上載者:User

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

  oExcelApp.Quit();
    
    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(Microsoft.Office.Interop.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進程了,

 

另外一個新發現的方法:

如果你某刻發現一個excel做模板然後載入excel應用對象,匯出資料如果excel進程自己會退出,那麼複製這個模板,然後清空內容,重新在這個摸板設計你x想要的模板內容,載入這個模板excel應用對象,匯出資料,那麼這個excel進程自己會很聽話的退掉,
我曾經測試過,再系統非常多使用者時同時點擊匯出excel報表也僅僅是2-3個進程,正常使用僅僅一個!前提是你要發現一個聽話的excel模板。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.