2

我正在尝试使用 OpenXML(SAX 方法)创建 Excel 文档。当我的方法被调用时,我想检查是否已经为给定的键创建了一个选项卡。如果是,我只想在该选项卡的底部附加一行。如果尚未为给定键创建选项卡,我将创建一个新选项卡,例如;

      part = wbPart.AddNewPart<WorksheetPart>();

                        string worksheetName = row.Key[i].ToString();

                        Sheet sheet = new Sheet() { Id = document.WorkbookPart.GetIdOfPart(part), SheetId = sheetNumber, Name = worksheetName };
                        sheets.Append(sheet);

                        writer = OpenXmlWriter.Create(part);
                        writer.WriteStartElement(new Worksheet());
                        writer.WriteStartElement(new SheetData());

                        currentrow = 1;

                        string header = Header + "\t" + wrapper.GetHeaderString(3, 2, -1); //need to fix
                        WriteDataToExcel(header, currentrow, 0, writer);
                        currentrow++;


                        writer.WriteEndElement();
                        writer.WriteEndElement();
                        writer.Close();

如果已经创建了一个选项卡,我会使用以下代码回忆工作表;

private static WorksheetPart GetWorksheetPartByName(SpreadsheetDocument document, string sheetName)
    {
        IEnumerable<Sheet> sheets =
           document.WorkbookPart.Workbook.GetFirstChild<Sheets>().
           Elements<Sheet>().Where(s => s.Name == sheetName);

        if (sheets.Count() == 0)
        {
            // The specified worksheet does not exist.

            return null;
        }

        string relationshipId = sheets.First().Id.Value;
        WorksheetPart worksheetPart = (WorksheetPart)
             document.WorkbookPart.GetPartById(relationshipId);
        return worksheetPart;

    }

当返回正确的 Worksheet 部分时,我尝试通过将 OpenXmlWriter 指向正确的部分然后添加行来添加新行;

   part = GetWorksheetPartByName(document, row.Key[i].ToString());

                        writer = OpenXmlWriter.Create(part);
                        writer.WriteStartElement(part.Worksheet);
                        writer.WriteStartElement(part.Worksheet.GetFirstChild<SheetData>());
                        SheetData sheetData = part.Worksheet.GetFirstChild<SheetData>();
                        Row lastRow = sheetData.Elements<Row>().LastOrDefault();

代码运行但是我总是只得到一行(我第一次创建选项卡时添加的初始行)。电子表格中不会显示后续行。

我将添加很多行(50,000+),并且不希望每次都创建新文件并复制信息。

4

2 回答 2

4

根据我的经验,使用 SAX 方法编写(即使用 OpenXmlWriter)最适合新事物(部件、工作表等)。当您使用 OpenXmlWriter.Create() 时,这就像覆盖部件(在本例中为 WorksheetPart)的原始现有数据。即使实际上,它不是。情况很复杂。

就我的实验而言,如果有现有数据,则无法使用 OpenXmlWriter 编辑数据。即使您使用 Save() 函数或正确关闭 OpenXmlWriter 也不行。出于某种原因,SDK 会忽略您的努力。因此,您添加的原始一行。

如果您要写入 50,000 行,最好一次性完成。那么 SAX 方法将很有用。此外,如果您正在编写一行(一次?),使用 SAX 与 DOM 方法相比的速度优势可以忽略不计。

于 2013-01-21T12:10:57.140 回答
0

根据此站点使用现有 Excel 与 OpenXMLWriter 一起工作:OpenXMLWriter 只能操作新工作表而不是现有文档。因此,恐怕您无法使用 OpenXMLWriter 将值插入到现有电子表格的特定单元格中。

您可以读取现有 Excel 文件中的所有数据,然后似乎您需要添加行(50,000+)我建议使用 openxmlwriter 将新旧数据一次写入新的 Excel 文件。如果您使用 DOM 方法,在追加大量行(50,000+)后可能会导致内存问题。

于 2019-01-17T04:05:44.547 回答