C #: Как я могу открыть и закрыть книгу Excel? - PullRequest
6 голосов
/ 06 октября 2009

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

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

Полагаю, мне понадобится ссылка на сборку Microsoft.Office.Interop.Excel.


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

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

Ответы [ 3 ]

11 голосов
/ 06 октября 2009

после ссылки на Microsoft.Office.Interop.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);


        }
3 голосов
/ 06 октября 2009

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

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

0 голосов
/ 06 октября 2009

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

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...