2017-09-06 78 views
1

嘗試引用此鏈接:SheetViews爲null試圖凍結行的OpenXML

https://social.msdn.microsoft.com/Forums/office/en-US/e1c08add-b610-44c9-b60e-fa8ef6c24978/openxmlexcelc?forum=oxmlsdk

我得到這個線的SheetView空指針異常:

的SheetView SW = wsp.Worksheet.SheetViews .FirstOrDefault()asSheetView;

創建我的電子表格時,我沒有使用任何sheetviews,和我使用的MemoryStream傳回使用。

使用此代碼:

我怎麼會凍頂兩行?謝謝!

MemoryStream ms = new MemoryStream(); 
     SpreadsheetDocument xl = SpreadsheetDocument.Create(ms, SpreadsheetDocumentType.Workbook); 

     WorkbookPart wbp = xl.AddWorkbookPart(); 
     WorksheetPart wsp = wbp.AddNewPart<WorksheetPart>(); 
     Workbook wb = new Workbook(); 
     FileVersion fv = new FileVersion(); 
     fv.ApplicationName = "Microsoft Office Excel"; 
     Worksheet ws = new Worksheet(); 

     SheetData sd = new SheetData(); 

     WorkbookStylesPart stylesPart = xl.WorkbookPart.AddNewPart<WorkbookStylesPart>(); 
     stylesPart.Stylesheet = GenerateStyleSheet(); 
     stylesPart.Stylesheet.Save(); 




     //create header 
     uint colHeaderIndex = 1; 
     Row r1 = new Row() { RowIndex = colHeaderIndex }; 
     foreach (System.ComponentModel.PropertyDescriptor descriptor in System.ComponentModel.TypeDescriptor.GetProperties(list[0])) 
     { 
      Cell headerCell = new Cell(); 
      headerCell.DataType = CellValues.String; 
      headerCell.CellValue = new CellValue(descriptor.DisplayName); 
      r1.Append(headerCell); 
     } 
     //append header row to sheet 
     sd.Append(r1); 


     //now fill the rest of the rows with data 
     uint rowIndex = 1; //Start at 1, since we reserved index 1 for the heading. The indexer will increase its value by 1 before it is used. 
     for (int i = 0; i < list.Count; i++) 
     { 
      uint colIndex = 1; 
      Row row = new Row() { RowIndex = ++rowIndex }; 
      foreach (System.ComponentModel.PropertyDescriptor descriptor in System.ComponentModel.TypeDescriptor.GetProperties(list[i])) 
      { 
       Cell cell = new Cell(); 
       cell.CellReference = rowIndex + " x " + colIndex; 
       cell.DataType = CellValues.String; 
       cell.StyleIndex = 1; 
       var val = descriptor.GetValue(list[i]); 
       cell.CellValue = new CellValue(val != null ? val.ToString() : ""); 
       row.Append(cell); 
      } 

      //append data row to sheet 
      sd.Append(row); 
     } 

     ws.Append(sd); 
     wsp.Worksheet = ws; 
     wsp.Worksheet.Save(); 
     Sheets sheets = new Sheets(); 
     Sheet sheet = new Sheet(); 
     sheet.Name = "first sheet"; 
     sheet.SheetId = 1; //we will only have one sheet for now, unless we are maxing out on sheets then we can create new ones 
     sheet.Id = wbp.GetIdOfPart(wsp); 
     sheets.Append(sheet); 
     wb.Append(fv); 
     wb.Append(sheets); 
     freezeHeader(wbp, wsp); 
     xl.WorkbookPart.Workbook = wb; 
     xl.WorkbookPart.Workbook.Save(); 

     xl.Close(); 

     Response.Clear(); 
     byte[] dt = ms.ToArray(); 

     Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"; 
     Response.AddHeader("Content-Disposition", string.Format("attachment; filename={0}.xlsx", fileName)); 
     Response.BinaryWrite(dt); 
     Response.End(); 

回答

1

通過使用開放的XML SDK 2.0生產力工具找出了這一點..顯然,附加到工作表的順序是一件大事。所以我也需要創建一個新的SheetViews列表的SheetView,但SheetViews列表需要被附加到工作表中的數據表以前。

因此增加,

SheetViews sheetViews1 = new SheetViews(); 

    SheetView sheetView1 = new SheetView() { TabSelected = true, WorkbookViewId = (UInt32Value)0U }; 
    Pane pane1 = new Pane() { VerticalSplit = 1D, TopLeftCell = "A2", ActivePane = PaneValues.BottomLeft, State = PaneStateValues.Frozen }; 
    Selection selection1 = new Selection() { Pane = PaneValues.BottomLeft, ActiveCell = "A2", SequenceOfReferences = new ListValue<StringValue>() { InnerText = "A2:XFD2" } }; 

    sheetView1.Append(pane1); 
    sheetView1.Append(selection1); 

    sheetViews1.Append(sheetView1); 

,並呼籲

ws.Append(sheetViews1); 

權利之前,

ws.Append(sd); 

工作。如果我以後sheetdata(SD)已追加然後附加文件會由於它扔錯誤成爲腐敗;我可以使用生產力工具查看。

使用這個工具,我可以用我的工作代碼,然後我愣在標題行內手動Excel和重新保存該文件(試圖凍結標題行)之前先打印我的Excel工作表。我打開這個新文件了裏面的工具,並且我能夠查看用於創建文檔的代碼,看到了追加的訂單。

希望這可以幫助別人。我能夠看到像這些沒有解決方案(或後續)的其他一些問題。