-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbook.go
53 lines (45 loc) · 1.06 KB
/
book.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
package Record2Excel
import (
"fmt"
"github.com/xuri/excelize/v2"
)
type WorkBook interface {
AddSheet(name string, model any, options ...Option) (Sheet, error)
UseSheet(name string) (Sheet, error)
Export() (*excelize.File, error)
}
type workBook struct {
file *excelize.File
sheets map[string]Sheet
}
func NewWorkBook() WorkBook {
return &workBook{
file: excelize.NewFile(),
sheets: make(map[string]Sheet),
}
}
func (w *workBook) AddSheet(name string, model any, options ...Option) (s Sheet, err error) {
w.sheets[name], err = newSheet(name, model, w.file, options...)
return w.sheets[name], err
}
func (w *workBook) UseSheet(name string) (s Sheet, err error) {
s, ok := w.sheets[name]
if !ok {
return nil, fmt.Errorf("sheet %s not found", name)
}
return s, nil
}
func (w *workBook) Export() (*excelize.File, error) {
for _, s := range w.sheets {
err := s.applyHeaderStyle()
if err != nil {
return nil, err
}
err = s.applyContentStyle()
if err != nil {
return nil, err
}
}
_ = w.file.DeleteSheet("Sheet1")
return w.file, nil
}