使用工作表

本主题讨论 Open XML SDK WorksheetChartsheetDialogSheet 类,以及它们与 Open XML 文件格式 SpreadsheetML 架构的关系。 有关构成 SpreadsheetML 文档的部件和元素的整体结构的详细信息,请参阅 SpreadsheetML 文档的结构

SpreadsheetML 中的工作表

ISO/IEC 29500 规范中的以下信息介绍了工作表 (<sheet/>) 元素。

工作表是工作簿内的核心结构,用户在工作表中执行大多数电子表格任务。 最常见的工作表类型是由单元格网格表示的工作表。 工作表单元格可以包含文本、数字、日期和公式。 用户还可以设置单元格的格式。 工作簿通常包含多个工作表。 为了帮助分析数据和做出明智的决策,电子表格应用程序通常实现可帮助计算、排序、筛选、组织和以图形方式显示信息的功能和对象。 因为这些功能通常与电子表格网格紧密关联,所以这些功能也包含在磁盘上的工作表定义中。

其他类型的工作表包括图表工作表和对话框工作表。

© ISO/IEC 29500:2016

Open XML SDK 工作表类

Open XML SDK Worksheet 类表示 worksheet 在 SpreadsheetML 文档的 Open XML 文件格式架构中定义的 (<worksheet/>) 元素。 Worksheet使用 类可操作 SpreadsheetML 文档中的各个<worksheet/>元素。

ISO/IEC 29500 规范中的以下信息介绍了 worksheet (<worksheet/>) 元素。

此部件类型的实例包含与给定工作表相关联的所有数据、公式和特征。

对于每个工作表,包应该正好包含一个 Worksheet 部件

具体地说,sheet 元素的 ID 属性应该引用所需的工作表部件。

此内容类型的部件的根元素应该为 worksheet。

来自 ISO/IEC 29500 规范的以下信息介绍了最小工作表方案。

可能的最小(空白)工作表如下所示:

<worksheet>
    <sheetData/>
</worksheet>

空 sheetData 集合表示一个空网格;此元素是必需的。 根据架构中的定义,一些可选的工作表属性集合可以出现在 sheetData 之前,一些可以出现在 sheetData 之后。 为了简化在现有工作表(但却是空表)中插入新 sheetData 集合所需的逻辑,sheetData 集合是必需的,即使对于空表也是如此。

© ISO/IEC 29500:2016

典型的电子表格至少包含一个工作表。 工作表包含一个类似表的结构,用于定义由 元素表示 sheetData 的数据。 包含数据的工作表使用 worksheet 元素作为定义工作表的根元素。 在工作表中,数据分为三个不同的部分。 第一部分包含可选的表属性。 第二部分使用所需的 sheetData 元素包含数据。 第三部分包含可选的支持功能,如工作表保护和筛选信息。 若要定义空工作表, worksheet 只需使用 和 sheetData 元素。 元素 sheetData 可以为空。

若要为工作表创建新值,请在 元素内 sheetData 定义行。 这些行包含具有值的单元格。 元素 row 定义新行。 通常, 中的 sheetData 第一行是可见工作表中的第一行。 在行内,使用 <c/> 元素新建cells。 可通过在单元格内存储 <v/> 元素来提供单元格的值。 通常, <v/> 元素包含工作表单元格的当前值。 如果值是数值,则直接 <v/> 存储在 XML 文件中的 元素中。 如果值是字符串值,则存储在共享字符串表格中。 有关使用共享字符串表存储字符串值的详细信息,请参阅 使用共享字符串表

下表列出了使用 Worksheet 类时使用的常见 Open XML SDK 类。

SpreadsheetML 元素 Open XML SDK 类
<sheetData/> SheetData
<row/> Row
<c/> Cell
<v/> CellValue

有关可选电子表格元素(如工作表属性和提供支持的表功能)的详细信息,请参阅 ISO/IEC 29500 规范。

SheetData 类

ISO/IEC 29500 规范中的以下信息介绍了 工作表数据 (<sheetData/>) 元素。

单元格表格是工作表的核心结构。 它包含网格中的所有文本、数字和公式。

© ISO/IEC 29500:2016

Row 类

ISO/IEC 29500 规范中的以下信息介绍了 (<row/>) 元素。

单元格表格中的单元格按行排列。 每行都有一个索引 (属性 r) ,因此不需要写出空行。每行指示为其定义的单元格数,以及它们在工作表中的相对位置。 在此示例中,第一个数据行是第 2 行。

© ISO/IEC 29500:2016

Cell 类

ISO/IEC 29500 规范中的以下信息介绍了 单元 (<c/>) 元素。

单元格本身由 c 集合表示。 每个单元格都使用 A1 样式的引用表示法指明它在网格中的位置。 单元格还可以指明样式标识符(属性 s)和数据类型(属性 t)。 单元格类型包括 string、number 和 Boolean。 为了优化加载/保存操作,不写出默认数据值。

© ISO/IEC 29500:2016

CellValue 类

ISO/IEC 29500 规范中的以下信息介绍了) 元素 (<v/>单元格值

单元格包含值,无论值是直接输入的值(例如,示例中的单元格 A2 包含值 External Link:)还是计算结果(例如,示例中的单元格 B3 包含公式 B2+1)。

单元格中的字符串值不存储在单元格表格中,除非它们是计算结果。 因此,与其看到外部链接作为单元格 v 节点的内容,不如在共享字符串表中看到一个从零开始的索引,该字符串是唯一存储的。 这样做是为了优化加载/保存性能和减少信息重复。 若要确定 v 中的 0 是数字还是字符串索引,必须检查单元格的数据类型。 当数据类型指示字符串时,则它是索引而不是数字值。

© ISO/IEC 29500:2016

Open XML SDK 代码示例

下面的代码示例创建一个具有指定文件名的电子表格文档,并实例化类 Worksheet ,然后添加一行并将单元格添加到单元格表中的 A1 位置。 然后,设置 A1 中的单元格值,使它等于数字值 100。

static void CreateSpreadsheetWorkbook(string filepath)
{
    // Use 'using' block to ensure proper disposal of the document
    using (SpreadsheetDocument spreadsheetDocument = SpreadsheetDocument.Create(filepath, SpreadsheetDocumentType.Workbook))
    {
        // Add a WorkbookPart to the document.
        WorkbookPart workbookPart = spreadsheetDocument.AddWorkbookPart();
        workbookPart.Workbook = new Workbook();

        // Add a WorksheetPart to the WorkbookPart.
        WorksheetPart worksheetPart = workbookPart.AddNewPart<WorksheetPart>();
        worksheetPart.Worksheet = new Worksheet(new SheetData());

        // Add Sheets to the Workbook.
        Sheets sheets = workbookPart.Workbook.AppendChild(new Sheets());

        // Append a new worksheet and associate it with the workbook.
        Sheet sheet = new Sheet() { Id = workbookPart.GetIdOfPart(worksheetPart), SheetId = 1, Name = "mySheet" };
        sheets.Append(sheet);

        // Get the sheetData cell table.
        SheetData sheetData = worksheetPart.Worksheet.GetFirstChild<SheetData>() ?? worksheetPart.Worksheet.AppendChild(new SheetData());

        // Add a row to the cell table.
        Row row = new Row() { RowIndex = 1 };
        sheetData.Append(row);

        // In the new row, find the column location to insert a cell in A1.  
        Cell? refCell = null;

        foreach (Cell cell in row.Elements<Cell>())
        {
            if (string.Compare(cell.CellReference?.Value, "A1", true) > 0)
            {
                refCell = cell;
                break;
            }
        }

        // Add the cell to the cell table at A1.
        Cell newCell = new Cell() { CellReference = "A1" };
        row.InsertBefore(newCell, refCell);

        // Set the cell value to be a numeric value of 100.
        newCell.CellValue = new CellValue("100");
        newCell.DataType = new EnumValue<CellValues>(CellValues.Number);
    }
}