程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 更多關於編程 >> 解析c#操作excel後關閉excel.exe的方法

解析c#操作excel後關閉excel.exe的方法

編輯:更多關於編程
    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.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();                  
       }


    以上代碼百分百成功的關閉excel.exe進程
    我的做法是結合兩者,先釋放資源,然後關閉進程。
    同時網上說避免使用GC.Collect 方法 (),因為會導致整個clr進行gc,影響你的性能.所以我也沒有調用GC.Collect

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved