excel.go 1.0KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. package utils
  2. import (
  3. "errors"
  4. "io"
  5. "reflect"
  6. "github.com/astaxie/beego"
  7. "github.com/tealeg/xlsx"
  8. )
  9. // TinyXLSXEngine 简版 xlsx 处理器
  10. type TinyXLSXEngine struct {
  11. xlsxFile *xlsx.File
  12. sheet *xlsx.Sheet
  13. }
  14. // NewTinyXLSXEngine init
  15. func NewTinyXLSXEngine() (*TinyXLSXEngine, error) {
  16. file := xlsx.NewFile()
  17. sheet, err := file.AddSheet("sheet1")
  18. if err != nil {
  19. beego.Error("创建 xlsx sheet 失败: " + err.Error())
  20. return nil, errors.New("创建 xlsx sheet 失败")
  21. }
  22. return &TinyXLSXEngine{
  23. xlsxFile: file,
  24. sheet: sheet,
  25. }, nil
  26. }
  27. // InsertRow 新增行
  28. func (t *TinyXLSXEngine) InsertRow() *xlsx.Row {
  29. return t.sheet.AddRow()
  30. }
  31. // SetCell 新增数据
  32. func (t *TinyXLSXEngine) SetCell(row *xlsx.Row, v interface{}) {
  33. rv := reflect.ValueOf(v)
  34. if rv.Kind() == reflect.Slice {
  35. for i := 0; i < rv.Len(); i++ {
  36. row.AddCell().SetValue(rv.Index(i).Interface())
  37. }
  38. } else {
  39. row.AddCell().SetValue(v)
  40. }
  41. }
  42. // Write 写数据
  43. func (t *TinyXLSXEngine) Write(w io.Writer) error {
  44. return t.xlsxFile.Write(w)
  45. }