excel_info.go 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "eta/eta_chart_lib/models"
  5. "eta/eta_chart_lib/models/request"
  6. "eta/eta_chart_lib/models/response"
  7. "eta/eta_chart_lib/services/data"
  8. "eta/eta_chart_lib/services/data/table"
  9. "eta/eta_chart_lib/services/excel"
  10. "eta/eta_chart_lib/utils"
  11. "time"
  12. )
  13. // ExcelInfoController excel表格
  14. type ExcelInfoController struct {
  15. BaseAuthController
  16. }
  17. // GetTableDetail
  18. // @Title 获取表格表详情
  19. // @Description 获取表格表详情接口
  20. // @Param UniqueCode query string true "表格表唯一编码,如果是管理后台访问,传固定字符串:7c69b590249049942070ae9dcd5bf6dc"
  21. // @Success 200 {object} response.ExcelTableDetailResp
  22. // @router /detail [get]
  23. func (this *ExcelInfoController) GetTableDetail() {
  24. br := new(models.BaseResponse).Init()
  25. defer func() {
  26. this.Data["json"] = br
  27. this.ServeJSON()
  28. }()
  29. uniqueCode := this.GetString("UniqueCode")
  30. if uniqueCode == "" {
  31. br.Msg = "参数错误"
  32. br.ErrMsg = "参数错误,uniqueCode is empty"
  33. return
  34. }
  35. key := utils.HZ_CHART_LIB_EXCEL_TABLE_DETAIL + ":" + uniqueCode
  36. resp := new(response.ExcelTableDetailResp)
  37. ////判断是否有缓存
  38. //if utils.Re == nil {
  39. // if utils.Re == nil && utils.Rc.IsExist(key) {
  40. // if data, err1 := utils.Rc.RedisBytes(key); err1 == nil {
  41. // err := json.Unmarshal(data, &resp)
  42. // if err == nil && resp != nil {
  43. // br.Ret = 200
  44. // br.Success = true
  45. // br.Msg = "获取成功"
  46. // br.Data = resp
  47. // fmt.Println("source redis")
  48. // return
  49. // }
  50. // }
  51. // }
  52. //}
  53. excelInfo, err := models.GetExcelInfoByUniqueCode(uniqueCode)
  54. if err != nil {
  55. if err.Error() == utils.ErrNoRow() {
  56. br.Msg = "该表格已被删除,请刷新页面"
  57. br.ErrMsg = "该表格已被删除,请刷新页面,Err:" + err.Error()
  58. return
  59. }
  60. br.Msg = "获取失败"
  61. br.ErrMsg = "获取表格表信息失败,Err:" + err.Error()
  62. return
  63. }
  64. var tableData excel.TableData
  65. switch excelInfo.Source {
  66. case utils.EXCEL_DEFAULT:
  67. luckySheetData, err := excel.GetLuckySheetData(excelInfo.Content)
  68. if err != nil {
  69. br.Msg = "获取失败"
  70. br.ErrMsg = "获取excel数据失败,Err:" + err.Error()
  71. return
  72. }
  73. tableData, err = luckySheetData.GetTableDataByLuckySheetDataStr()
  74. if err != nil {
  75. br.Msg = "获取失败"
  76. br.ErrMsg = "转换成table失败,Err:" + err.Error()
  77. return
  78. }
  79. case utils.TIME_TABLE:
  80. var tableDataConfig data.TableDataConfig
  81. err = json.Unmarshal([]byte(excelInfo.Content), &tableDataConfig)
  82. if err != nil {
  83. br.Msg = "获取失败"
  84. br.ErrMsg = "表格json转结构体失败,Err:" + err.Error()
  85. return
  86. }
  87. result, err := data.GetDataByTableDataConfig(tableDataConfig)
  88. if err != nil {
  89. br.Msg = "获取失败"
  90. br.ErrMsg = "获取最新的表格数据失败,Err:" + err.Error()
  91. return
  92. }
  93. tableData, err = excel.GetTableDataByCustomData(excelInfo.ExcelType, result)
  94. if err != nil {
  95. br.Msg = "获取失败"
  96. br.ErrMsg = "转换成table失败,Err:" + err.Error()
  97. return
  98. }
  99. case utils.MIXED_TABLE:
  100. var result request.MixedTableReq
  101. err = json.Unmarshal([]byte(excelInfo.Content), &result)
  102. if err != nil {
  103. br.Msg = "获取失败"
  104. br.ErrMsg = "表格json转结构体失败,Err:" + err.Error()
  105. return
  106. }
  107. newResult, tmpErr, tmpErrMsg := table.GetMixedTableCellData(result)
  108. if tmpErr != nil {
  109. br.Msg = "获取失败"
  110. if tmpErrMsg != `` {
  111. br.Msg = tmpErrMsg
  112. }
  113. br.ErrMsg = "获取最新的数据失败,Err:" + tmpErr.Error()
  114. return
  115. }
  116. tableData, err = excel.GetTableDataByMixedTableData(newResult)
  117. if err != nil {
  118. br.Msg = "获取失败"
  119. br.ErrMsg = "转换成table失败,Err:" + err.Error()
  120. return
  121. }
  122. }
  123. tableData = excel.HandleTableCell(tableData)
  124. resp.TableInfo = tableData
  125. resp.Source = excelInfo.Source
  126. resp.ExcelType = excelInfo.ExcelType
  127. resp.ExcelName = excelInfo.ExcelName
  128. resp.ExcelImage = excelInfo.ExcelImage
  129. resp.UniqueCode = excelInfo.UniqueCode
  130. if utils.Re == nil {
  131. data, _ := json.Marshal(resp)
  132. utils.Rc.Put(key, data, 10*time.Minute)
  133. }
  134. br.Ret = 200
  135. br.Success = true
  136. br.Msg = "获取成功"
  137. br.Data = resp
  138. }