8

如何在 OpenXml 中设置一行(或整行)中多个单元格的背景?

看了几篇文章:

  1. 在 C# 中使用 openXML 为 Excel 工作表中的单元格着色
  2. Excel Open XML 中的高级样式

我仍然无法让它工作。

我的任务实际上乍一看似乎更容易一些,并且与那些文章中写的有点不同。上面提到的教程主要展示了如何创建一个新文档并设置它的样式。虽然我需要更改现有样式的样式。

也就是说,我有一个现有的xlsx文档(报告模板)。我用必要的值填充报告(由于SO open xml excel 读取单元格值MSDN Working with sheet (Open XML SDK))。但接下来我需要用红色背景标记几行。

我不确定是否使用CellStyle或是否应该使用CellFormat或其他东西......这就是我现在所做的:

SpreadsheetDocument doc = SpreadsheetDocument.Open("ole.xlsx", true);

Sheet sheet = (Sheet)doc.WorkbookPart
                        .Workbook
                        .Sheets
                        .FirstOrDefault();

WorksheetPart worksheetPart = (WorksheetPart)doc.WorkbookPart
                                                .GetPartById(sheet.Id);
Worksheet worksheet = worksheetPart.Worksheet;


CellStyle cs = new CellStyle();
cs.Name = StringValue.FromString("Normal");
cs.FormatId = 0;
cs.BuiltinId = 0;
//where are the style values?

WorkbookStylesPart wbsp = doc.WorkbookPart
                                .GetPartsOfType<WorkbookStylesPart>()
                                .FirstOrDefault();
wbsp.Stylesheet.CellStyles.Append(cs);
wbsp.Stylesheet.Save();



Cell cell = GetCell(worksheet, "A", 20);
cell.StyleIndex = 1U;//get the new cellstyle index somehow

doc.Close();

实际上,我将非常感谢一个更轻量级和简单的示例,说明如何设置单元格A20或范围 from A20to的样式J20。或者可能是指向更多连续教程的链接。

4

2 回答 2

9

最后我改变主意使用单元格背景并使用字体。感谢fosonSO Creating Excel document with OpenXml sdk 2.0中的回答,我设法添加了一个新的Font和一个新的CellFormat,保留了原始单元格的格式(即仅更改了字体颜色):

SpreadsheetDocument doc = SpreadsheetDocument.Open("1.xlsx", true);
Sheet sheet = (Sheet)doc.WorkbookPart.Workbook.Sheets.FirstOrDefault();
WorksheetPart worksheetPart = (WorksheetPart)doc.WorkbookPart
                                                .GetPartById(sheet.Id);
Worksheet worksheet = worksheetPart.Worksheet;

WorkbookStylesPart styles = doc.WorkbookPart.WorkbookStylesPart;
Stylesheet stylesheet = styles.Stylesheet;
CellFormats cellformats = stylesheet.CellFormats;
Fonts fonts = stylesheet.Fonts;

UInt32 fontIndex = fonts.Count;
UInt32 formatIndex = cellformats.Count;

Cell cell = GetCell(worksheet, "A", 19);
cell.CellValue = new CellValue(DateTime.Now.ToLongTimeString());
cell.DataType = new EnumValue<CellValues>(CellValues.String);

CellFormat f = (CellFormat)cellformats.ElementAt((int)cell.StyleIndex.Value);

var font = (Font)fonts.ElementAt((int)f.FontId.Value);
var newfont = (Font)font.Clone();
newfont.Color = new Color() { Rgb = new HexBinaryValue("ff0000") };
fonts.Append(newfont);

CellFormat newformat = (CellFormat)f.Clone();
newformat.FontId = fontIndex;
cellformats.Append(newformat);

stylesheet.Save();

cell.StyleIndex = formatIndex;
doc.Close();
于 2012-12-28T01:16:53.180 回答
1

您有 3 个选项:

  1. 使用 MS lib ExcelDataReader,它需要您的服务器安装 Office,如果您的程序在 IIS 中运行,通常无法正常工作。

  2. 使用闭源库。

  3. 使用 OpenXML。

使用纯 OpenXML 尝试我的代码: https ://stackoverflow.com/a/59806422/6782249

于 2020-01-19T01:51:18.023 回答