C#: Как открыть и закрыть книгу Excel?

кто-нибудь знает, как просто открыть и закрыть книгу Excel?

Мне не нужно читать данные из файла, мне просто нужно открыть и закрыть его. (*)

Я предполагаю, что мне нужно будет ссылаться на Microsoft.Офис.Взаимодействие.Сборка в Excel.


*причина: я уже настроил информацию сводной таблицы с сторонней библиотекой (Aspose). Теперь мне нужно прочитать сгенерированную сводную таблицу.

к сожалению, Библиотека Aspose не может генерировать сводную таблицу во время выполнения. Ему нужен кто-то, чтобы открыть файл с помощью Excel чтобы Excel мог генерировать значения сводной таблицы.

3 ответов


после ссылки на Microsoft.Офис.Взаимодействие.Excel также убедитесь, что очистить в конце концов.

using Excel = Microsoft.Office.Interop.Excel;

        Excel.ApplicationClass _Excel;
        Excel.Workbook WB;
        Excel.Worksheet WS;

    try
        {

        _Excel = new Microsoft.Office.Interop.Excel.ApplicationClass();
        WB = _Excel.Workbooks.Open("FILENAME",
            Type.Missing, Type.Missing, Type.Missing, Type.Missing,
            Type.Missing, Type.Missing, Type.Missing, Type.Missing,
            Type.Missing, Type.Missing, Type.Missing, Type.Missing,
            Type.Missing, Type.Missing);

            //do something

        }
        catch (Exception ex)
        {
            WB.Close(false, Type.Missing, Type.Missing);

            throw;
        }
        finally
        {
            GC.Collect();
            GC.WaitForPendingFinalizers();

            System.Runtime.InteropServices.Marshal.FinalReleaseComObject(WB);

            System.Runtime.InteropServices.Marshal.FinalReleaseComObject(_Excel);


        }

быстрый Google дает мне это в проекте кода:

http://www.codeproject.com/KB/office/csharp_excel.aspx


рассмотрите возможность использования системы.Диагностика.Процесс запуска, мониторинга и закрытия Excel. Этот сайт дает хорошее вступление:http://www.thescarms.com/dotnet/Process.aspx, включая запуск с невидимым окном и отправку в него ввода.