如何将数据写入excel模板并在OpenXML中保持模板格式?

  • 本文关键字:OpenXML 格式 数据 excel openxml
  • 更新时间 :
  • 英文 :


我能够使用openxml读取excel模板,并能够将数据附加到工作表。但无法维持现有的Excel模板格式,无法识别列标题

请查找下面使用的代码

if (ds.Tables.Count > 0 && ds.Tables[0] != null || ds.Tables[0].Columns.Count > 0)
{
System.Data.DataTable table = ds.Tables[0];
using (var spreadsheetDocument = SpreadsheetDocument.Open(filePath, true))
{
WorkbookPart workbookPart = spreadsheetDocument.WorkbookPart;
Sheet sheet = spreadsheetDocument.WorkbookPart.Workbook.Sheets.GetFirstChild<Sheet>();
Worksheet worksheet = (spreadsheetDocument.WorkbookPart.GetPartById(sheet.Id.Value) as WorksheetPart).Worksheet;
SheetData sheetData = worksheet.GetFirstChild<SheetData>();
List<String> columns = new List<string>();
IEnumerable<Row> rows = worksheet.GetFirstChild<SheetData>().Descendants<Row>();
foreach (DataColumn column in table.Columns)
{
columns.Add(column.ColumnName);
Cell cell = new Cell();
cell.DataType = CellValues.String;
cell.CellValue = new CellValue(column.ColumnName);
}

foreach (DataRow row in table.Rows)
{
Row newRow = new Row();
columns.ForEach(col =>
{
Cell cell = new Cell();
//If value is DBNull, do not set value to cell  
if (row[col] != System.DBNull.Value)
{
cell.DataType = CellValues.String;
cell.CellValue = new CellValue(row[col].ToString());
}
newRow.AppendChild(cell);
});
sheetData.AppendChild(newRow);
}
spreadsheetDocument.WorkbookPart.Workbook.Save();
spreadsheetDocument.Close();
}

请找到实际的excel截图

请找到预期的excel截图

请说明您的具体问题,并提供您正在使用的实际代码片段和示例模板,以便我们更好地了解您的问题并帮助您解决问题。

之前有一篇文章"OpenXML SDK 2.5 Excel模板";在模板中找到名称为DataField的标签,并替换为data。这可能就是你要找的。

相关内容

  • 没有找到相关文章

最新更新