我有一个Visual Basic .NET程序,需要打开和关闭Excel电子表格.打开和阅读电子表格工作正常,但尝试关闭Excel 2007应用程序会导致它挂起.它似乎关闭,但如果你查看任务管理器,应用程序仍在运行.我用来关闭它的代码是
wbkData.Close(saveChanges:=False) appExcel.Quit() wbkData = Nothing appExcel = Nothing
如何让Excel正常关闭?
我想在这里讨论了你的问题的答案: 如何正确清理c中的excel互操作对象
我无法从你的代码示例中看到,但基本上,总是将你的excel对象分配给局部变量,永远不要'两个点',如下所示:
//FAIL Workbook wkBook = xlApp.Workbooks.Open(@"C:\mybook.xls");
而是单独ref每个obj:
//WIN Worksheets sheets = xlApp.Worksheets; Worksheet sheet = sheets.Open(@"C:\mybook.xls"); ... Marshal.ReleaseComObject(sheets); Marshal.ReleaseComObject(sheet);
.NET为您不可见的COM对象创建一个包装器,直到GC编织其魔法才会释放.
直到我发现这个,我每次创建一个新工作簿时都会在ASP.NET应用程序中运行下面的hacky代码,该工作簿检查excel.exe进程的年龄并杀死任何超过一分钟的时间:
//force kill any excel processes over one minute old. try { Process[] procs = Process.GetProcessesByName("EXCEL"); foreach (Process p in procs) { if (p.StartTime.AddMinutes(1) < DateTime.Now) { p.Kill(); } } } catch (Exception) {}