首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Excel Interop,Excel的延迟实例

Excel Interop,Excel的延迟实例
EN

Stack Overflow用户
提问于 2018-11-13 09:20:47
回答 2查看 96关注 0票数 0

简单的代码,我认为它应该杀死Excel。但是任务管理器说这会让Excel的一个实例运行。我遗漏了什么?谢谢。

代码语言:javascript
复制
using Microsoft.Office.Interop.Excel;
//Stuff...
// Launch dialog picker that return path to Excel file, in string
// called excelTemplate
Microsoft.Office.Interop.Excel.Application xlTemp = new Microsoft.Office.Interop.Excel.Application();
Workbook workbook = xlTemp.Workbooks.Open(excelTemplate);
xlTemp.DisplayAlerts = false;

// Poke through individual sheets, get some info from them

 workbook.Close();
 xlTemp.Quit();
EN

回答 2

Stack Overflow用户

发布于 2018-11-13 09:28:13

代码语言:javascript
复制
Application xlTemp = new Application();
Workbooks workbooks = xlTemp.Workbooks;
Workbook workbook = workbooks.Open(excelTemplate);

// Do stuff.

workbook.Close();
Marshal.ReleaseComObject(workbook);
Marshal.ReleaseComObject(workbooks);
xlTemp.Quit();
Marshal.ReleaseComObject(xlTemp);

除了需要释放每个COM对象之外,还要注意,通过执行xlTemp.Workbooks.Open,如果不将xlTemp.Workbooks赋给可以稍后释放的变量,则会泄漏COM引用。

票数 0
EN

Stack Overflow用户

发布于 2018-11-13 09:27:51

您可以使用#using来自动处置应用程序。

代码语言:javascript
复制
using(Microsoft.Office.Interop.Excel.Application xlTemp = new 
Microsoft.Office.Interop.Excel.Application())
{
   Workbook workbook = xlTemp.Workbooks.Open(excelTemplate);
   xlTemp.DisplayAlerts = false;

   // Poke through individual sheets, get some info from them

   workbook.Close();
}
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53272412

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档