我有一个 Windows服务,通过Microsoft.Office.Interop.Excel.Application对象打开一个Excel电子表格.
Application xlApp = new Application();
Workbook workbook = xlApp.Workbooks.Open(fileName,2,false);
...
...
workbook.Close();
xlApp.Quit();

在完成工作簿之后,我想杀死EXCEL.exe进程.

我试过以下,没有成功…

// This returns a processId of 0
IntPtr processId;
GetwindowThreadProcessId(new IntPtr(xlApp.Hwnd),out processId);
Process p = Process.GetProcessById(processId.ToInt32());   
p.Kill();

任何人有什么想法,通过Windows服务如何做到这一点?

正确关闭打开的Excel工作簿并退出应用程序是非常困难的.如果我可以找到我将发布的链接,但实质上您必须清理所有对您创建的任何COM对象的引用.这包括来自ODBCConnections(数据连接),Worksheets,Workbooks和Excel应用程序的所有内容.我的工作涉及垃圾收集和System.Runtime.InteropServices.Marshal对象的组合:
// Garbage collecting
GC.Collect();
GC.WaitForPendingFinalizers();
// Clean up references to all COM objects
// As per above,you're just using a Workbook and Excel Application instance,so release them:
workbook.Close(false,Missing.Value,Missing.Value);
xlApp.Quit();
Marshal.FinalReleaseComObject(workbook);
Marshal.FinalReleaseComObject(xlApp);

像你所说的,循环和杀死每个Excel进程通常不是一个好主意,因为如果你作为一个Windows应用程序运行它,你可以关闭Excel在您的用户,或在一个服务也关闭正在运行的Excel实例通过一些其他程序.

编辑:有关更多信息,请参阅this question.

在Windows服务中从C#中杀死EXCEL.exe进程的更多相关文章

  1. xcode4 – 如何将excel文件类型(xlsx)与iPhone应用程序相关联

    您好,我已经通过向项目构建添加文档类型并将Types字段设置为“com.microsoft.excel.xls”(请参阅屏幕截图),通过邮件应用程序打开.xls文件.我想对xlsx文件做同样的处理,但不能做.我尝试添加“com.microsoft.excel.xlsx”但是没有起作用解决方法我通过定义自定义UTI解决了如下.尝试将这些定义添加到您的info.plist中.它按预期工作.….

  2. regex – Microsoft Excel中的正则表达式子串替换

    我想用国际版“447”批量替换字符串列表的“07”部分.字符串列表当前在Excel电子表格中形成一个列.我有正则表达式来匹配需要修改的字符串:……但我不知道如何进行我需要的替换.数据位于Excel电子表格中,但当然可以导出.首选解决方案是将数据保存在MicrosoftExcel中,但它当然可以导出然后重新导入.我知道TextMate有一个正则表达式替换功能.这可以帮到我吗?

  3. windows-7 – Windows 7:“Excel发现不可读的内容”

    我正在使用PHPExcel生成一个非常简单的.xls文件(PHPExcel_IOFactory::createWriter($PHPExcel,’Excel5′)).每当使用Excel2010或2007在Windows7上打开该文件时,我都会收到以下错误:Excel在“XXXXXXX.xls”中找到了不可读的内容.您想恢复此工作簿的内容吗?如果您信任此工作簿的来源,请单击“是”.当我在Window

  4. 在Windows服务中从C#中杀死EXCEL.exe进程

    任何人有什么想法,通过Windows服务如何做到这一点?

  5. 如何在Microsoft Excel中打开以空格分隔的文件?

    当我尝试在excel中打开空格分隔文件时,整个内容将在单个列中打开.有没有办法打开excel中的空格分隔文件,以便将分隔的内容正确格式化为不同的列?我的情况是我有一个文件,需要分隔符是”',因为我的文件格式是这样的:使用标准的“打开”命令.然后转到“文本导入向导”并选择原始数据类型是分隔的.您可能需要转到向导的另一个步骤以指定分隔符是空格,但向导确实包含指定分隔符所属字符的选项.

  6. 使用php excel将徽标添加到Excel工作表

    我正在尝试使用下面的代码列表在生成的Excel工作表上添加徽标图像,但由于某种原因它什么都不做添加徽标非常简单,请尝试以下代码.

  7. 如何从PHP导入Excel文件到mysql数据库

    让我们说,我想从PHP导入/上传excel文件到MysqL我的HTML如下PHP代码如下Excel文件如下我想仅将第二行值导入到我的表中.请帮助我如何解决它或给我任何资源.我能够上传excel文件,但格式不正确.我想在MysqL的4列中上传4列,但是它正在上传MysqL的1列中的所有4列.我错过了什么吗?

  8. PHPExcel reader – 需要帮助

    告诉我们如何改进它.编辑2使用最新的SVN代码来利用rangetoArray()方法:

  9. 在php中使用simplexlsx阅读excel xlsx文件

    但代码中的某个地方必须有一种处理该转换的方法,所以我会假设还有一个反向的方法编辑你想要的方法是在代码中:我不保证这是准确的编辑进一步给这看起来非常像在今年的正确范围内的unix时间戳值,并且确实如此:所以看起来像对我有用

  10. phpmyadmin替代(ajax,excel-like)

    (如果我搜索“PHPmyadmin和excel”,我得到的答案像“热wo导入excel文件”….)我搜索一个PHPmyadmin替代工作更快与ajax,我想编辑一次字段直接像EXCEL!点击n编辑通过ajax!我不喜欢点击该行,并说“现在编辑”,然后编辑,然后单击“确定”,返回和新加载仅编辑一个字段:-(我希望你有我的答案.Adminer(以前称为PHPMinAdmin)并不错.他们还有一个专门的编辑界面,称为AdminerEditor.

随机推荐

  1. static – 在页面之间共享数据的最佳实践

    我想知道在UWP的页面之间发送像’selectedItem’等变量的最佳做法是什么?创建一个每个页面都知道的静态全局变量类是一个好主意吗?

  2. .net – 为Windows窗体控件提供百分比宽度/高度

    WindowsForm开发的新手,但在Web开发方面经验丰富.有没有办法为Windows窗体控件指定百分比宽度/高度,以便在用户调整窗口大小时扩展/缩小?当窗口调整大小时,可以编写代码来改变控件的宽度/高度,但我希望有更好的方法,比如在HTML/CSS中.在那儿?

  3. 使用Windows Azure查询表存储数据

    我需要使用特定帐户吗?>将应用程序部署到Azure服务后,如何查询数据?GoogleAppEngine有一个数据查看器/查询工具,Azure有类似的东西吗?>您可以看到的sqlExpressintance仅在开发结构中,并且一旦您表示没有等效,所以请小心使用它.>您可以尝试使用Linqpad查询表格.看看JamieThomson的thispost.

  4. windows – SetupDiGetClassDevs是否与文档中的设备实例ID一起使用?

    有没有更好的方法可以使用DBT_DEVICEARRIVAL事件中的数据获取设备的更多信息?您似乎必须指定DIGCF_ALLCLASSES标志以查找与给定设备实例ID匹配的所有类,或者指定ClassGuid并使用DIGCF_DEFAULT标志.这对我有用:带输出:

  5. Windows Live ID是OpenID提供商吗?

    不,WindowsLiveID不是OpenID提供商.他们使用专有协议.自从他们的“测试版”期结束以来,他们从未宣布计划继续它.

  6. 如果我在代码中进行了更改,是否需要重新安装Windows服务?

    我写了一个Windows服务并安装它.现在我对代码进行了一些更改并重新构建了解决方案.我还应该重新安装服务吗?不,只需停止它,替换文件,然后重新启动它.

  7. 带有双引号的字符串回显使用Windows批处理输出文件

    我正在尝试使用Windows批处理文件重写配置文件.我循环遍历文件的行并查找我想要用指定的新行替换的行.我有一个’函数’将行写入文件问题是%Text%是一个嵌入双引号的字符串.然后失败了.可能还有其他角色也会导致失败.如何才能使用配置文件中的所有文本?尝试将所有“在文本中替换为^”.^是转义字符,因此“将被视为常规字符你可以尝试以下方法:其他可能导致错误的字符是:

  8. .net – 将控制台应用程序转换为服务?

    我正在寻找不同的优势/劣势,将我们长期使用的控制台应用程序转换为Windows服务.我们为ActiveMQ使用了一个叫做java服务包装器的东西,我相信人们告诉我你可以用它包装任何东西.这并不是说你应该用它包装任何东西;我们遇到了这个问题.控制台应用程序是一个.NET控制台应用程序,默认情况下会将大量信息记录到控制台,尽管这是可配置的.任何推荐?我们应该在VisualStudio中将其重建为服务吗?我使用“-install”/“-uninstall”开关执行此操作.例如,seehere.

  9. windows – 捕获外部程序的STDOUT和STDERR *同时*它正在执行(Ruby)

    哦,我在Windows上:-(实际上,它比我想象的要简单,这看起来很完美:…是的,它适用于Windows!

  10. windows – 当我试图批量打印变量时,为什么我得到“Echo is on”

    我想要执行一个简单的批处理文件脚本:当我在XP中运行时,它给了我预期的输出,但是当我在Vista或Windows7中运行它时,我在尝试打印值时得到“EchoisOn”.以下是程序的输出:摆脱集合表达式中的空格.等号(=)的两侧可以并且应该没有空格BTW:我通常在@echo关闭的情况下启动所有批处理文件,并以@echo结束它们,所以我可以避免将代码与批处理文件的输出混合.它只是使您的批处理文件输出更好,更清洁.

返回
顶部