2013-04-25 65 views
1

如何发布为我的下面的代码创建的excel实例?杀死excel实例。发布excel实例

Excel.Workbook Workbook1 = xCel.Workbooks.Open(ExcelFilePath);     
Excel.Workbook Workbook2 = xCel.Workbooks.Add(); 

foreach (Excel.Worksheet dummysheet in Workbook1.Worksheets) 
{     
    dummysheet.Copy(Workbook2.Worksheets[1],Type.Missing); 
} 
Workbook2.SaveAs(strFileCopyPath); 

//代码发布练成实例

if (sourceWorkbook != null) 
       {     
        sourceWorkbook = null; 
        destinationWorkbook = null; 
        Thread.Sleep(500); 
       } 
       if (status.ProcessID > 0) 
       {      
        Process p = Process.GetProcessById(status.ProcessID); 
        p.Kill(); 
       } 

       GC.Collect(); 
       GC.WaitForPendingFinalizers(); 
       GC.Collect(); 
       GC.WaitForPendingFinalizers(); 

       try { Marshal.FinalReleaseComObject(sourceWorkbook); } 
       catch { } 
       try { Marshal.FinalReleaseComObject(destinationWorkbook); } 
       catch { } 

请检查,如果这是正确的。

我知道这是重复的,所有我叫你们的人是检查这是否正确。

+0

也许看这里的答案 - http://stackoverflow.com/q/9581689/2065121 – 2013-04-25 07:09:48

+0

不要使用每行超过一个点时,使用互操作对象。所以像这样:'ES.oXL.Workbooks.Open(ExcelFilePath)'不幸的是需要分成4行。这在@ TimSchmelter的评论 – Dan 2013-04-25 07:13:32

回答

0

可以使用下列内容:

GC.Collect(); 
GC.WaitForPendingFinalizers(); 
GC.Collect(); 
GC.WaitForPendingFinalizers(); 
+0

@Filburt OP在这篇文章后编辑了他的问题。 – Freelancer 2013-04-25 07:10:21

+0

好吧,我的坏...我刚刚检查了历史,错过了编辑自己的用户编辑 – Filburt 2013-04-25 07:12:14

+0

好吧,谢谢你的分号。 – Freelancer 2013-04-25 07:14:23