在C#中操纵EXCEL或者WORD之类的东西,应该很多人都做过,不过在调用完之后,我们好象都有一些头痛的事情,那就是结束这些进程.很多书都没有说,很多论坛上也没有.我在上一个项目中也遇到过这样的问题,但是后来做了一些尝试,发现真的有解决方案的.
public
static
bool
KillExcelProcess(Application excel)
![](https://i-blog.csdnimg.cn/blog_migrate/a41954a27d6ad96fa2c2cf816e677448.gif)
...
{
int hwnd = excel.Hwnd;
Process p = null;
foreach (Process temp in Process.GetProcessesByName("EXCEL"))
![](https://i-blog.csdnimg.cn/blog_migrate/37c8bf68cdc3cc81759c34160776bc53.gif)
...{
if (temp.MainWindowHandle.ToInt32() == hwnd)
![](https://i-blog.csdnimg.cn/blog_migrate/37c8bf68cdc3cc81759c34160776bc53.gif)
...{
p = temp;
temp.Kill();
return true;
}
}
return false;
}
int
hwnd
=
excel.Hwnd;
UInt32[] processId
=
new
UInt32[
1
];
GetWindowThreadProcessId((IntPtr)hwnd, processId);
Process p
=
Process.GetProcessById(Convert.ToInt32(processId[
0
]));
p.Kill();
[DllImport(
"
user32.dll
"
, CharSet
=
CharSet.Auto)]
public
static
extern
UInt32 GetWindowThreadProcessId(IntPtr hWnd, UInt32[] processID);
解决方案有两种:
一,就是创建的EXCEL或者WORD是可见的,也就是VISIABLE值为TRUE.那么我们可以用一种很简单的方法结束这个进程.
代码如下
![](https://i-blog.csdnimg.cn/blog_migrate/6810355c2f78c12e91b7997a8e8c583a.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/a41954a27d6ad96fa2c2cf816e677448.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/1327ab569c1ae82736693a50b8e33378.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/37c8bf68cdc3cc81759c34160776bc53.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/7ff8d92cded7e0ce15e7ca1acc870052.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/37c8bf68cdc3cc81759c34160776bc53.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/7ff8d92cded7e0ce15e7ca1acc870052.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/717446ca04a6125dc5b6b54e0fa14ab4.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/717446ca04a6125dc5b6b54e0fa14ab4.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/0196c3df5ea9e936f21e9932cca91014.gif)
这段程序可以结束掉程序建立的可见的EXCEL进程,(也就是说你建立EXCEL进程是不是不可以将VISIALBE属性设为FALSE)
可是在现实中我们除了可以在服务器端将VISIABLE设为TRUE外,其他的情况都是肯定不行的.因为没有人可以忍受自己的电脑上有一大堆EXCLE的窗口.所以我们就要用以下的方法.
代码如下:
![](https://i-blog.csdnimg.cn/blog_migrate/6810355c2f78c12e91b7997a8e8c583a.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6810355c2f78c12e91b7997a8e8c583a.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6810355c2f78c12e91b7997a8e8c583a.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6810355c2f78c12e91b7997a8e8c583a.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6810355c2f78c12e91b7997a8e8c583a.gif)
在这段程序中我们将会用到GetWindowThreadProcessId这个函数,这是一个WIN函数,那么我们在使用这个函数的时候要先添加这个函数的入口.代码如下
![](https://i-blog.csdnimg.cn/blog_migrate/6810355c2f78c12e91b7997a8e8c583a.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6810355c2f78c12e91b7997a8e8c583a.gif)
这样我们就可以很容易的结束掉我们的应用程序创建的EXCEL进程了.记住是我们的程序创建的,不是用户创建的.