c# - Excel 对象有时不会被处理

标签 c# excel tdd

我有这段代码用于读取 excel 单元格:

 public T GetValue<T>(string testsheet, string range)
    {
        Application excelApplication    = null;
        Workbooks workBooks             = null;
        Workbook activeWorkBook         = null;
        Worksheet activeWorkSheet       = null;

        try
        {
            excelApplication    = new Application();
            workBooks           = excelApplication.Workbooks;
            activeWorkBook      = workBooks.Open(workBook);

            activeWorkSheet     = activeWorkBook.ActiveSheet;
            var cells           = activeWorkSheet.get_Range(range);
            return cells.Value2;

        }
        catch (Exception theError)
        {
            Console.WriteLine(theError.Message);
            throw theError;
        }
        finally
        {         
            ReleaseComObject(activeWorkSheet);
            ReleaseComObject(activeWorkBook);
            ReleaseComObject(workBooks);
            ReleaseComObject(excelApplication);
        }            
    }

我还有一个 Set value 方法,它将值设置为单元格,如下所示:

public void SetValue<T>(string testsheet, string range, T value)
    {
        Application excelApplication = null;
        Workbooks workBooks = null;
        Workbook activeWorkBook = null;
        Worksheet activeWorkSheet = null;

        try
        {
            excelApplication = new Application();
            workBooks = excelApplication.Workbooks;
            activeWorkBook = workBooks.Open(workBook);

            activeWorkSheet = activeWorkBook.ActiveSheet;
            var cells = activeWorkSheet.get_Range(range);
            cells.Value2 = value;
            activeWorkBook.Save();             
        }
        catch (Exception theError)
        {
            Console.WriteLine(theError.Message);
            throw theError;
        }
        finally
        {
            if (activeWorkBook != null)
                activeWorkBook.Close();

            ReleaseComObject(excelApplication);
            ReleaseComObject(workBooks);
            ReleaseComObject(activeWorkBook);
            ReleaseComObject(activeWorkSheet);                                                
        }           
    }

这是我的 ReleaseComObject:

  private static void ReleaseComObject<T>(T comObject) where T : class
    {
        if (comObject != null)
            Marshal.ReleaseComObject(comObject);
    }

我已经编写了一个测试来确保 excel 对象被正确处理如下:

  [Test]
    public void Should_dispose_excel_objects_created_after_io_operation()
    {
        var expected = Process.GetProcesses().Count(process => process.ProcessName.ToLower() == "excel");

        var automationClient = new ExcelAutomation.ExcelAutomationClient(ExcelSheet);

        automationClient.SetValue("Sheet1", "A1", 1200);
        automationClient.GetValue<double>("Sheet1", "A1");

        var actual = Process.GetProcesses().Count(process => process.ProcessName.ToLower() == "excel");

        actual.Should().Be(expected, "Excel workbook is not disposed properly. There are still excel processess in memory");
    }

如果我只调用 SetValue 方法,则此测试通过,但是在调用 GetValue 时它会失败。但是我在任务管理器中看不到 Excel.exe。知道为什么会这样吗?我的 GetValue 函数有问题吗?

最佳答案

处理完对象后,使用

GC.Collect();

这就是我处理 Excel 对象的方式

        private void releaseObject(object obj)
    {
        try
        {
            System.Runtime.InteropServices.Marshal.ReleaseComObject(obj);
            obj = null;
        }
        catch (Exception ex)
        {
            obj = null;
            MessageBox.Show("Exception Occured while releasing object " + ex.ToString());
        }
        finally
        {
            GC.Collect();
        }
    }

关于c# - Excel 对象有时不会被处理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9185992/

相关文章:

php - Yii2 excel导入 'PHPExcel_IOFactory'未找到

asp.net-mvc - Moq - 如何模拟 HttpContext.Request.Url.Authority 对象等非虚拟成员?

c# - 如何解决密封类的不可能继承?

c# - 如何从 Type 的名称中获取 Type 对象?

c# - Rtf to Html 删除 html 表

java - 带有 jasper 报告的动态列

c# - 如何使用 DataContext 绑定(bind)到 List<T>?

excel - 查找在一个范围内具有共同列的唯一单元格的数量

reactjs - 如何使用 Jest 和 Enzyme 在 React 中测试函数

ruby - 我可以在开始的项目中以 TDD 或 BDD 为目标吗?