解析c#操作excel后關(guān)閉excel.exe的方法
更新時間:2013年07月09日 09:09:34 作者:
C#和Asp.net下excel進程一被打開,有時就無法關(guān)閉,尤其是website.對關(guān)閉該進程有過GC、release等方法,但這些方法并不是在所有情況下均適用
于是提出了kill process的方法,目前我見過的方法多是用進程創(chuàng)建時間篩選excel.exe進程,然后kill 。這樣的方法是不精確的,也是不安全的,通過對網(wǎng)上一些關(guān)于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.xls", Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);
IntPtr t = new IntPtr(excel.Hwnd);
int k = 0;
GetWindowThreadProcessId(t, out k);
System.Diagnostics.Process p = System.Diagnostics.Process.GetProcessById(k);
p.Kill();
}
以上代碼百分百成功的關(guān)閉excel.exe進程
我的做法是結(jié)合兩者,先釋放資源,然后關(guān)閉進程。
同時網(wǎng)上說避免使用GC.Collect 方法 (),因為會導(dǎo)致整個clr進行g(shù)c,影響你的性能.所以我也沒有調(diào)用GC.Collect
以下就是代碼
復(fù)制代碼 代碼如下:
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.xls", Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);
IntPtr t = new IntPtr(excel.Hwnd);
int k = 0;
GetWindowThreadProcessId(t, out k);
System.Diagnostics.Process p = System.Diagnostics.Process.GetProcessById(k);
p.Kill();
}
以上代碼百分百成功的關(guān)閉excel.exe進程
我的做法是結(jié)合兩者,先釋放資源,然后關(guān)閉進程。
同時網(wǎng)上說避免使用GC.Collect 方法 (),因為會導(dǎo)致整個clr進行g(shù)c,影響你的性能.所以我也沒有調(diào)用GC.Collect
相關(guān)文章
適用于WebForm Mvc的Pager分頁組件C#實現(xiàn)
這篇文章主要為大家分享了適用于WebForm Mvc的Pager分頁組件,由C#實現(xiàn),感興趣的小伙伴們可以參考一下2016-04-04
C# LINQ查詢表達式及對應(yīng)LAMBDA表達式的用法
這篇文章主要介紹了C# LINQ查詢表達式及對應(yīng)LAMBDA表達式的用法,幫助大家更好的理解和學(xué)習(xí)使用c#,感興趣的朋友可以了解下2021-04-04
C#生成指定范圍內(nèi)的不重復(fù)隨機數(shù)
對于隨機數(shù),大家都知道,計算機不 可能產(chǎn)生完全隨機的數(shù)字,所謂的隨機數(shù)發(fā)生器都是通過一定的算法對事先選定的隨機種子做復(fù)雜的運算,用產(chǎn)生的結(jié)果來近似的模擬完全隨機數(shù),這種隨機數(shù)被稱 作偽隨機數(shù)。偽隨機數(shù)是以相同的概率從一組有限的數(shù)字中選取的。2015-05-05

