结束EXCEL进程

在C#中操纵EXCEL或者WORD之类的东西,应该很多人都做过,不过在调用完之后,我们好象都有一些头痛的事情,那就是结束这些进程.很多书都没有说,很多论坛上也没有.我在上一个项目中也遇到过这样的问题,但是后来做了一些尝试,发现真的有解决方案的.     

       解决方案有两种:    

      一,就是创建的EXCEL或者WORD是可见的,也就是VISIABLE值为TRUE.那么我们可以用一种很简单的方法结束这个进程.  

       代码如下

   public   static   bool  KillExcelProcess(Application excel)
        
{
            
int hwnd = excel.Hwnd;
            Process p 
= null;
            
foreach (Process temp in Process.GetProcessesByName("EXCEL"))
            
{
                
if (temp.MainWindowHandle.ToInt32() == hwnd)
                
{
                    p 
= temp;
                    temp.Kill();
                    
return true;
                }

            }

            
return false;
        }

          这段程序可以结束掉程序建立的可见的EXCEL进程,(也就是说你建立EXCEL进程是不是不可以将VISIALBE属性设为FALSE)

       可是在现实中我们除了可以在服务器端将VISIABLE设为TRUE外,其他的情况都是肯定不行的.因为没有人可以忍受自己的电脑上有一大堆EXCLE的窗口.所以我们就要用以下的方法.

       代码如下:

             int  hwnd  =  excel.Hwnd;
            UInt32[] processId 
=   new  UInt32[ 1 ];
            GetWindowThreadProcessId((IntPtr)hwnd, processId);
            Process p 
=  Process.GetProcessById(Convert.ToInt32(processId[ 0 ]));
            p.Kill();

         在这段程序中我们将会用到GetWindowThreadProcessId这个函数,这是一个WIN函数,那么我们在使用这个函数的时候要先添加这个函数的入口.代码如下

       [DllImport( " user32.dll " , CharSet  =  CharSet.Auto)]
        
public   static   extern  UInt32 GetWindowThreadProcessId(IntPtr hWnd, UInt32[] processID);

这样我们就可以很容易的结束掉我们的应用程序创建的EXCEL进程了.记住是我们的程序创建的,不是用户创建的.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值