Объединить клетки с помощью EPPlus? - PullRequest
73 голосов
/ 30 мая 2011

Я использую библиотеку EPPlus для чтения / записи файлов Excel: http://epplus.codeplex.com/

Я пытаюсь просто объединить несколько ячеек при написании документа:

using (ExcelPackage pck = new ExcelPackage())
{
    //Create the worksheet
    ExcelWorksheet ws = pck.Workbook.Worksheets.Add("Demo");

    //Format the header for column 1-3
    using (ExcelRange rng = ws.Cells["A1:C1"])
    {
        bool merge = rng.Merge;
    }
}

Есть свойство с именем Merge, которое просто возвращает true или false. Я думал, может быть, это объединит клетки, но это не так.

Кто-нибудь знает, как это сделать?

Ответы [ 3 ]

132 голосов
/ 30 мая 2011

Вы должны использовать это так:

ws.Cells["A1:C1"].Merge = true;

вместо:

using (ExcelRange rng = ws.Cells["A1:C1"])
{
    bool merge = rng.Merge;
}
62 голосов
/ 02 сентября 2014

Если вы хотите объединить ячейки динамически, вы также можете использовать:

worksheet.Cells[FromRow, FromColumn, ToRow, ToColumn].Merge = true;

Все эти переменные являются целыми числами.

4 голосов
/ 26 января 2017

Вы можете создать метод расширения:

public static void Merge(this ExcelRangeBase range)
{
    ExcelCellAddress start = range.Start;
    ExcelCellAddress end = range.End;
    range.Worksheet.Cells[start.Row, start.Column, end.Row, end.Column].Merge = true;
}

Вы можете использовать это как при взаимодействии:

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