流式写入

StreamWriter 用于定义流式写入器的数据类型。

  1. type StreamWriter struct {
  2. File *File
  3. Sheet string
  4. SheetID int
  5. // 还包含其他已过滤或未导出的字段
  6. }

CellStreamWriter.SetRow 中使用,用于指定单元格的值、公式和样式。

  1. type Cell struct {
  2. StyleID int
  3. Formula string
  4. Value interface{}
  5. }

RowOptsStreamWriter.SetRow 中使用,用于设置行样式。

  1. type RowOpts struct {
  2. Height float64
  3. Hidden bool
  4. StyleID int
  5. OutlineLevel int
  6. }

获取流式写入器

  1. func (f *File) NewStreamWriter(sheet string) (*StreamWriter, error)

NewStreamWriter 通过给定的工作表名称返回流式写入器,用于生成包含大规模数据的工作表。请注意通过此方法按行向工作表写入数据后,必须调用 Flush 函数来结束流式写入过程,并需要确所保写入的行号是递增的,普通函数不能与流式函数混合使用在工作表中写入数据。例如,向工作表流式按行写入 102400 行 x 50 列带有样式的数据:

  1. file := excelize.NewFile()
  2. defer func() {
  3. if err := file.Close(); err != nil {
  4. fmt.Println(err)
  5. }
  6. }()
  7. streamWriter, err := file.NewStreamWriter("Sheet1")
  8. if err != nil {
  9. fmt.Println(err)
  10. }
  11. styleID, err := file.NewStyle(&excelize.Style{Font: &excelize.Font{Color: "#777777"}})
  12. if err != nil {
  13. fmt.Println(err)
  14. }
  15. if err := streamWriter.SetRow("A1",
  16. []interface{}{
  17. excelize.Cell{StyleID: styleID, Value: "Data"},
  18. []excelize.RichTextRun{
  19. {Text: "Rich ", Font: &excelize.Font{Color: "2354e8"}},
  20. {Text: "Text", Font: &excelize.Font{Color: "e83723"}},
  21. },
  22. },
  23. excelize.RowOpts{Height: 45, Hidden: false}); err != nil {
  24. fmt.Println(err)
  25. }
  26. for rowID := 2; rowID <= 102400; rowID++ {
  27. row := make([]interface{}, 50)
  28. for colID := 0; colID < 50; colID++ {
  29. row[colID] = rand.Intn(640000)
  30. }
  31. cell, _ := excelize.CoordinatesToCellName(1, rowID)
  32. if err := streamWriter.SetRow(cell, row); err != nil {
  33. fmt.Println(err)
  34. }
  35. }
  36. if err := streamWriter.Flush(); err != nil {
  37. fmt.Println(err)
  38. }
  39. if err := file.SaveAs("Book1.xlsx"); err != nil {
  40. fmt.Println(err)
  41. }

流式设置单元格的公式和值:

  1. err := streamWriter.SetRow("A1", []interface{}{
  2. excelize.Cell{Value: 1},
  3. excelize.Cell{Value: 2},
  4. excelize.Cell{Formula: "SUM(A1,B1)"}})

流式设置单元格的值和行样式:

  1. err := streamWriter.SetRow("A1", []interface{}{
  2. excelize.Cell{Value: 1}},
  3. excelize.RowOpts{StyleID: styleID, Height: 20, Hidden: false})

流式设置单元格的值和行行的分级显示:

  1. err := streamWriter.SetRow("A1", []interface{}{
  2. excelize.Cell{Value: 1}}, excelize.RowOpts{OutlineLevel: 1})

按行流式写入工作表

  1. func (sw *StreamWriter) SetRow(cell string, values []interface{}, opts ...RowOpts) error

SetRow 通过给定的起始坐标和指向数组类型“切片”的指针将数据按行流式写入工作表中。请注意,在设置行之后,必须调用 Flush 函数来结束流式写入过程,并需要确所保写入的行号是递增的。

流式创建表格

  1. func (sw *StreamWriter) AddTable(hCell, vCell, opts string) error

根据给定的单元格坐标区域和条件格式流式创建表格。

例1,在 A1:D5 区域流式创建表格:

  1. err := streamWriter.AddTable("A1", "D5", "")

例2,在工作表 F2:H6 区域创建带有条件格式的表格:

  1. err := streamWriter.AddTable("F2", "H6", `{
  2. "table_name": "table",
  3. "table_style": "TableStyleMedium2",
  4. "show_first_column": true,
  5. "show_last_column": true,
  6. "show_row_stripes": false,
  7. "show_column_stripes": true
  8. }`)

注意,表格坐标区域至少需要包含两行:字符型的标题行和内容行。每列标题行的字符需保证是唯一的,当前仅支持在每个工作表中流式创建一张表格,并且必须在调用该函数前通过 SetRow 流式设置表格的标题行数据。支持的表格样式与非流式创建表格 AddTable 相同。

流式插入分页符

  1. func (sw *StreamWriter) InsertPageBreak(cell string) error

根据给定的单元格坐标流式插入分页符。分页符是将工作表分成单独的页面以便打印的分隔线。

流式设置窗格

  1. func (sw *StreamWriter) SetPanes(panes string) error

通过给定的窗格样式参数流式设置冻结窗格,必须在调用 SetRow 之前调用该函数设置窗格。

流式合并单元格

  1. func (sw *StreamWriter) MergeCell(hCell, vCell string) error

通过给定的单元格坐标区域流式合并单元格,当前仅支持合并非交叠区域单元格。

流式设置列宽度

  1. func (sw *StreamWriter) SetColWidth(min, max int, width float64) error

根据给定的列范围和宽度值设置单个或多个列的宽度,必须在调用 SetRow 之前调用该函数设置列宽度。例如设置工作表上 BC 列的宽度为 20

  1. err := streamWriter.SetColWidth(2, 3, 20)

结束流式写入

  1. func (sw *StreamWriter) Flush() error

Flush 用于结束流式写入过程。