如何使用 OpenXML 包自动调整 excel 列

How to AutoFit excel column using OpenXML Package

此代码使用 openxml 包生成 Excel 电子表格。请任何人告诉如何自动调整其列宽。

OpenXmlPackage.SpreadsheetDocument spreadsheetDocument = OpenXmlPackage.SpreadsheetDocument.Create(downloadFilePath, OpenXml.SpreadsheetDocumentType.Workbook);
// Add a WorkbookPart to the document.
OpenXmlPackage.WorkbookPart workbookpart = spreadsheetDocument.AddWorkbookPart();
// Add a WorksheetPart to the WorkbookPart.
workbookpart.Workbook = new OpenXmlSpreadsheet.Workbook();
int numDates = datesObject.Length;

// Add Sheets to the Workbook.
OpenXmlSpreadsheet.Sheets sheets = new OpenXmlSpreadsheet.Sheets();
OpenXml.UInt32Value sheetId = 1;

OpenXmlPackage.WorksheetPart firstWorksheetPart = workbookpart.AddNewPart<OpenXmlPackage.WorksheetPart>();
firstWorksheetPart.Worksheet = new OpenXmlSpreadsheet.Worksheet(new OpenXmlSpreadsheet.SheetData());
// Append a new worksheet and associate it with the workbook.
OpenXmlSpreadsheet.Sheet firstSheet = new OpenXmlSpreadsheet.Sheet() { Id = spreadsheetDocument.WorkbookPart.GetIdOfPart(firstWorksheetPart), SheetId = sheetId, Name = "Summary" };
sheets.Append(firstSheet);
sheetId++;

 OpenXmlSpreadsheet.SheetData firstSheetData = firstWorksheetPart.Worksheet.GetFirstChild<OpenXmlSpreadsheet.SheetData>();

 DataTable summaryTable = new DataTable();
 summaryTable.Clear();
 summaryTable.Columns.Add("name");
 summaryTable.Columns.Add("value");

 DataRow _summaryInfo = summaryTable.NewRow();
 _summaryInfo["name"] = "Clinic Name";
 _summaryInfo["value"] = userInfo[0];
 summaryTable.Rows.Add(_summaryInfo);



 int firstRowCount = summaryTable.Rows.Count;

 for (int rowNumber = 1; rowNumber <= firstRowCount; rowNumber++)
 {
      DataRow dataRow = summaryTable.Rows[rowNumber - 1];
      OpenXmlSpreadsheet.Row contentRow = ExcelHandler.createContentRow(dataRow, rowNumber);
      firstSheetData.AppendChild(contentRow);
 }

 firstWorksheetPart.Worksheet.Save();

自动调整逻辑是由 Microsoft Excel 实现的,不是 OpenXML 电子表格格式的一部分。自动调整涉及测量每个单元格中值的宽度(或高度)并找到最大值。

为了在您自己的代码中实现自动调整,您将不得不手动测量文本;您可以将 TextRenderer.MeasureTextGraphics.MeasureString 与适当的格式标志一起使用(禁用前缀字符)。这将为您提供以像素为单位的大小,您需要将其转换为 Excel 的复杂列宽单位。这个公式是:

width = Truncate([{字符数} * {最大数字宽度} + {5 像素填充}]/{最大数字宽度}*256)/256

摘自这篇文章:Column Class (DocumentFormat.OpenXml.Spreadsheet)

(最大数字宽度可以通过使用工作簿的默认字体测量 '0' 字符的宽度来确定 - 告诉你它很复杂!)

使用此公式获得单元格宽度后,您可以找到最大值并将其应用于 Column.Width 属性.

Microsoft Excel 呈现文本的方式存在细微差别(与 GDI/GDI+ 相比),因此此方法并非 100% 准确 - 但对于大多数用途而言已足够你总是可以添加一些额外的填充物以确保合适。