一直被一個問題困擾就是導出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模板。