lucky_sheet_excel.go 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. package excel
  2. import "github.com/tealeg/xlsx"
  3. type LuckySheet struct {
  4. SheetList []LuckySheetData `description:"sheet数据"`
  5. }
  6. // GetExcelData 通过 luckySheetData获取excel表格数据
  7. func (item *LuckySheet) GetExcelData(isRemoveBlankCell bool) (xlsxFile *xlsx.File, err error) {
  8. xlsxFile = xlsx.NewFile()
  9. if err != nil {
  10. return
  11. }
  12. for _, sheet := range item.SheetList {
  13. tableData, tmpErr := sheet.GetTableDataByLuckySheetDataStr(isRemoveBlankCell)
  14. if tmpErr != nil {
  15. err = tmpErr
  16. return
  17. }
  18. err = tableData.WriteExcelSheetData(xlsxFile, sheet.Name)
  19. if err != nil {
  20. return
  21. }
  22. }
  23. return
  24. }
  25. // ToExcel 通过 luckySheetData生成excel表格文件
  26. func (item *LuckySheet) ToExcel(isRemoveBlankCell bool) (downloadFilePath string, err error) {
  27. // 获取生成的excel路径
  28. downloadFilePath, err = getDownloadPath()
  29. if err != nil {
  30. return
  31. }
  32. // 获取excel表格数据
  33. xlsxFile, err := item.GetExcelData(isRemoveBlankCell)
  34. if err != nil {
  35. return
  36. }
  37. // 文件保存
  38. err = xlsxFile.Save(downloadFilePath)
  39. return
  40. }