OpenXML SDK - Excel 更改单元格格式 - C#

OpenXML SDK - Excel Change Cell Format - C#

我有一个 C# 网络应用程序。 并且正在使用 xlsx 模板来创建文档。 xlsx 的格式相当复杂,因此我选择了模板路径,而不是从头开始创建。 在一个单元格 x2 中,大多数数据以百分比形式出现,但在某些情况下它会是一个数量。但是当它达到百分比时,我似乎无法更改该单元格的格式。该模板以百分比格式保存在该单元格中。设置单元格值的代码如下,适用于以货币格式保存的其他单元格。我尝试根据具有相同格式的另一个单元格中的代码将单元格样式索引设置为 103U。

如何更改单元格 x2 的格式?任何帮助将不胜感激。提前致谢。`

public void setCellValueNum(WorksheetPart ws, int row, int col, Double newVal)
    {
        Cell cl = getCell(ws.Worksheet, getColLetter(col), row);
        cl.CellValue = new CellValue(newVal.ToString());
        cl.CellReference = getColLetter(col) + row.ToString();
        cl.DataType =
            new EnumValue<CellValues>(CellValues.Number);

        //cl.StyleIndex = (UInt32Value)103U;

       }

查看编号格式的一种样式。 Add style to Excel in openxml.

根据Reading dates from OpenXml Excel files,内置了 ID 值小于 164 的格式。您可以在那里找到格式列表。

这是一个例子:Applying % number format to a cell value using OpenXMl。只需将格式更改为

nf2decimal.FormatCode = StringValue.FromString("0.0");

您需要添加引用单元格的样式。这是一个例子:https://blogs.msdn.microsoft.com/chrisquon/2009/11/30/stylizing-your-excel-worksheets-with-open-xml-2-0/

openXML 安装了一个工具来生成 c# 代码以创建选定的 xlsx (https://tech.trailmax.info/2014/04/open-xml-sdk-tool-to-analyse-documents-and-generated-c-code/)。

我使用以下代码行将格式从百分比更改为货币。这是可行的,因为默认情况下已将基本数字格式添加到文件中。

cell.StyleIndex = 103U