Почему моя последовательность WorkbookView продолжает возвращать «нулевое» значение с OpenXml? - PullRequest
0 голосов
/ 30 сентября 2019

Я создал кнопку загрузки в C # / asp.net, которая берет GridView, преобразует его в таблицу данных и затем сохраняет его в файл .xlsx. После этого я хочу изменить активную вкладку созданной таблицы.

Вот код ниже:

 protected void downloadBtn_Click(object sender, EventArgs e)
    {

        using (var spreadSheet = SpreadsheetDocument.Create(Server.MapPath("~/Downloads/TestSheet.xlsx"), DocumentFormat.OpenXml.SpreadsheetDocumentType.Workbook))
        {
            WorkbookPart workbookPart = spreadSheet.AddWorkbookPart();
            workbookPart.Workbook = new Workbook();

            WorksheetPart worksheetPart = workbookPart.AddNewPart<WorksheetPart>();
            worksheetPart.Worksheet = new Worksheet(new SheetData());

            //Fine up to this point

            spreadSheet.WorkbookPart.Workbook.Sheets = new Sheets();

            DataTable table = new DataTable();
            //Converts GridView into Data Table **
            for (int i = 0; i < gvEmployee.HeaderRow.Cells.Count - 1; i++)
            {

                table.Columns.Add(gvEmployee.HeaderRow.Cells[i + 1].Text);
            }
            // fill rows     
            for (int i = 0; i < gvEmployee.Rows.Count; i++)
            {
                DataRow dr = table.NewRow();
                for (int j = 0; j < gvEmployee.Columns.Count - 1; j++)
                {
                    dr[j] = gvEmployee.Rows[i].Cells[j + 1].Text;
                }
                table.Rows.Add(dr);

            }

            var sheetPart = spreadSheet.WorkbookPart.AddNewPart<WorksheetPart>();
            var sheetData = new SheetData();
            sheetPart.Worksheet = new Worksheet(sheetData);

            Sheets sheets = spreadSheet.WorkbookPart.Workbook.GetFirstChild<Sheets>();
            string relationshipId = spreadSheet.WorkbookPart.GetIdOfPart(sheetPart);

            uint sheetId = 1;
            if (sheets.Elements<Sheet>().Count() > 0)
            {
                sheetId = sheets.Elements<Sheet>().Select(s => s.SheetId.Value).Max() + 1;
            }

            Sheet sheet = new Sheet() { Id = relationshipId, SheetId = sheetId, Name = "TestSheet" };
            sheets.Append(sheet);

            Row headerRow = new Row();
            List<String> columns = new List<string>();
            foreach (DataColumn column in table.Columns)
            {

                columns.Add(column.ColumnName);

                Cell cell = new Cell();
                cell.DataType = CellValues.String;
                cell.CellValue = new CellValue(column.ColumnName);
                headerRow.AppendChild(cell);
            }


            sheetData.AppendChild(headerRow);
            foreach (DataRow dsrow in table.Rows)
            {
                Row newRow = new Row();
                foreach (String col in columns)
                {
                    Cell cell = new Cell();
                    cell.DataType = CellValues.String;
                    cell.CellValue = new CellValue(dsrow[col].ToString()); //
                    newRow.AppendChild(cell);
                }

                sheetData.AppendChild(newRow);
            }


            Sheet sheet2 = new Sheet() { Id = spreadSheet.WorkbookPart.GetIdOfPart(sheetPart), SheetId = 2, Name = "AdditionalSheet" };
            sheets.Append(sheet2);

            var sheetIndex = workbookPart.Workbook.Descendants<Sheet>().ToList().IndexOf(sheet2);
            WorkbookView workbookView = workbookPart.Workbook.Descendants<WorkbookView>().FirstOrDefault(); //new WorkbookView();
            workbookView.ActiveTab = Convert.ToUInt32(sheetIndex);

            workbookPart.Workbook.Save();
            spreadSheet.Close();

        }
    }

Когда я пытаюсь запустить этот код, онв последних нескольких строках выдает ошибку «workbookView.ActiveTab», в которой указывается

System.NullReferenceException: 'Ссылка на объект не установлена ​​на экземпляр объекта.'

workbookView был нулевым.

Есть идеи, почему он это делает?

1 Ответ

0 голосов
/ 04 октября 2019

Хорошо, я только что понял, что не так, не было инициализированного WorkbookView, так как я подумал, что это не нужно. Но вы должны на самом деле создать WorkbookView вашей рабочей книги, прежде чем сможете ее изменить. Мне просто нужна была одна строка:

            workbookPart.Workbook.Append(new BookViews(new WorkbookView()));
...