Epplus: Как получить высоту строки после установки стиля столбца wraptext в true?

После того, как я установил столбец WrapText = true, я хочу посмотреть, какова будет новая высота строки (т.е. если текст обертывается, сколько строк). Похоже, что свойство Height строки не обновляется.

        ExcelPackage pkg = new ExcelPackage();
        ExcelWorksheet sheet = pkg.Workbook.Worksheets.Add("Test");

        // height is 15.0
        double heightBefore = sheet.Row(1).Height;


        sheet.Cells[1, 1].Value = "Now is the time for all good men to come to the aid of their country";

        ExcelColumn col = sheet.Column(1);

        // this will resize the width to 60
        col.AutoFit();

        if (col.Width > 50)
        {
            col.Width = 50;

            // this is just a style property, and doesn't actually execute any recalculations
            col.Style.WrapText = true;
        }

        // so this is still 15.0.  How do I get it to compute what the size will be?
        double heightAfter = sheet.Row(1).Height;

        // open the xls, and the height is 30.0
        pkg.SaveAs(new System.IO.FileInfo("text.xlsx"));

Фактически поиск свойства Height (или базового поля _height) показывает, что он задан только установщиком свойств и никогда не кажется установленным на основе чего-либо еще (например, содержимого в строке).

Любые идеи о том, как я могу получить обновленную высоту для строки?

Спасибо

Ответ 1

Общий шаблон, который я заметил в EPPlus, заключается в том, что он создает структуру документа с минимальным объемом необходимой информации. Затем, когда вы открываете файл, Excel заполняет оставшуюся структуру XML, поэтому вы всегда должны сохранять файл после открытия документа, созданного EPPlus.

По вашему вопросу, я предполагаю, что Excel обновляет высоту строки после открытия файла Excel, поэтому EPPlus не будет иметь обновленную информацию о высоте строки. Я не совсем уверен, что библиотека этого не поддерживает, но, как и вы, я не смог найти способ получить обновленные значения.

Однако одним обходным решением может быть просто рассчитать, какое значение будет иметь значение, поскольку вы знаете длину текста и ширину столбца:

ExcelPackage pkg = new ExcelPackage();
ExcelWorksheet sheet = pkg.Workbook.Worksheets.Add("Test");

// height is 15.0
double heightBefore = sheet.Row(1).Height;

var someText = "Now is the time for all good men to come to the aid of their country. Typewriters were once ground-breaking machines.";
sheet.Cells[1, 1].Value = someText;

ExcelColumn col = sheet.Column(1);
ExcelRow row = sheet.Row(1);

// this will resize the width to 60
col.AutoFit();

if (col.Width > 50)
{
    col.Width = 50;

    // this is just a style property, and doesn't actually execute any recalculations
    col.Style.WrapText = true;
}

// calculate the approximate row height and set the value;
var lineCount = GetLineCount(someText, (int)col.Width);
row.Height = heightBefore * lineCount;

// open the xls, and the height is 45.0
pkg.SaveAs(new System.IO.FileInfo("text.xlsx"));

Здесь метод вычисления числа строк:

private int GetLineCount(String text, int columnWidth)
{
    var lineCount = 1;
    var textPosition = 0;

    while (textPosition <= text.Length)
    {
        textPosition = Math.Min(textPosition + columnWidth, text.Length);
        if (textPosition == text.Length)
            break;

        if (text[textPosition - 1] == ' ' || text[textPosition] == ' ')
        {
            lineCount++;
            textPosition++;
        }
        else
        {
            textPosition = text.LastIndexOf(' ', textPosition) + 1;

            var nextSpaceIndex = text.IndexOf(' ', textPosition);
            if (nextSpaceIndex - textPosition >= columnWidth)
            {
                lineCount += (nextSpaceIndex - textPosition) / columnWidth;
                textPosition = textPosition + columnWidth;
            }
            else
                lineCount++;
        }
    }

    return lineCount;
}

Следует иметь в виду, что Excel имеет максимальную высоту строки 409,5, поэтому вам нужно убедиться, что ширина столбца не такая узкая, что вы достигнете этого предела.

Кроме того, я заметил, что ширины столбцов, которые вы вручную установили с помощью EPPlus, фактически не устанавливают столбцы в ожидаемое значение. Например, если вы установите ширину столбца на 50, вы заметите, что фактическая ширина столбца установлена ​​равной 49,29, поэтому вы можете также учитывать это.