excel_info.go 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  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. "github.com/shopspring/decimal"
  12. "time"
  13. )
  14. // ExcelInfoController excel表格
  15. type ExcelInfoController struct {
  16. BaseAuthController
  17. }
  18. // GetTableDetail
  19. // @Title 获取表格表详情
  20. // @Description 获取表格表详情接口
  21. // @Param UniqueCode query string true "表格表唯一编码,如果是管理后台访问,传固定字符串:7c69b590249049942070ae9dcd5bf6dc"
  22. // @Param FromScene query int true "场景来源,1:智能研报,2:研报列表;3:英文研报;4:中文PPT;5:英文PPT"
  23. // @Success 200 {object} response.ExcelTableDetailResp
  24. // @router /detail [get]
  25. func (this *ExcelInfoController) GetTableDetail() {
  26. br := new(models.BaseResponse).Init()
  27. defer func() {
  28. this.Data["json"] = br
  29. this.ServeJSON()
  30. }()
  31. uniqueCode := this.GetString("UniqueCode")
  32. if uniqueCode == "" {
  33. br.Msg = "参数错误"
  34. br.ErrMsg = "参数错误,uniqueCode is empty"
  35. return
  36. }
  37. fromScene, _ := this.GetInt("FromScene", 0)
  38. key := utils.HZ_CHART_LIB_EXCEL_TABLE_DETAIL + ":" + uniqueCode
  39. resp := new(response.ExcelTableDetailResp)
  40. //判断是否有缓存
  41. if utils.Re == nil {
  42. if utils.Re == nil && utils.Rc.IsExist(key) {
  43. if data, err1 := utils.Rc.RedisBytes(key); err1 == nil {
  44. err := json.Unmarshal(data, &resp)
  45. if err == nil && resp != nil {
  46. br.Ret = 200
  47. br.Success = true
  48. br.Msg = "获取成功"
  49. br.Data = resp
  50. return
  51. }
  52. }
  53. }
  54. }
  55. excelInfo, err := models.GetExcelInfoByUniqueCode(uniqueCode)
  56. if err != nil {
  57. if err.Error() == utils.ErrNoRow() {
  58. br.Msg = "该表格已被删除,请刷新页面"
  59. br.ErrMsg = "该表格已被删除,请刷新页面,Err:" + err.Error()
  60. return
  61. }
  62. br.Msg = "获取失败"
  63. br.ErrMsg = "获取表格表信息失败,Err:" + err.Error()
  64. return
  65. }
  66. var tableData excel.TableData
  67. switch excelInfo.Source {
  68. case utils.EXCEL_DEFAULT:
  69. luckySheetData, err := excel.GetLuckySheetData(excelInfo.Content)
  70. if err != nil {
  71. br.Msg = "获取失败"
  72. br.ErrMsg = "获取excel数据失败,Err:" + err.Error()
  73. return
  74. }
  75. tableData, err = luckySheetData.GetTableDataByLuckySheetDataStr()
  76. if err != nil {
  77. br.Msg = "获取失败"
  78. br.ErrMsg = "转换成table失败,Err:" + err.Error()
  79. return
  80. }
  81. case utils.TIME_TABLE:
  82. var tableDataConfig data.TableDataConfig
  83. err = json.Unmarshal([]byte(excelInfo.Content), &tableDataConfig)
  84. if err != nil {
  85. br.Msg = "获取失败"
  86. br.ErrMsg = "表格json转结构体失败,Err:" + err.Error()
  87. return
  88. }
  89. result, err := data.GetDataByTableDataConfig(tableDataConfig)
  90. if err != nil {
  91. br.Msg = "获取失败"
  92. br.ErrMsg = "获取最新的表格数据失败,Err:" + err.Error()
  93. return
  94. }
  95. tableData, err = excel.GetTableDataByCustomData(excelInfo.ExcelType, result)
  96. if err != nil {
  97. br.Msg = "获取失败"
  98. br.ErrMsg = "转换成table失败,Err:" + err.Error()
  99. return
  100. }
  101. case utils.MIXED_TABLE:
  102. var result request.MixedTableReq
  103. err = json.Unmarshal([]byte(excelInfo.Content), &result)
  104. if err != nil {
  105. br.Msg = "获取失败"
  106. br.ErrMsg = "表格json转结构体失败,Err:" + err.Error()
  107. return
  108. }
  109. newResult, tmpErr, tmpErrMsg := table.GetMixedTableCellData(result)
  110. if tmpErr != nil {
  111. br.Msg = "获取失败"
  112. if tmpErrMsg != `` {
  113. br.Msg = tmpErrMsg
  114. }
  115. br.ErrMsg = "获取最新的数据失败,Err:" + tmpErr.Error()
  116. return
  117. }
  118. tableData, err = excel.GetTableDataByMixedTableData(newResult)
  119. if err != nil {
  120. br.Msg = "获取失败"
  121. br.ErrMsg = "转换成table失败,Err:" + err.Error()
  122. return
  123. }
  124. }
  125. tableData = excel.HandleTableCell(tableData)
  126. config := response.ExcelTableDetailConfigResp{
  127. FontSize: 9,
  128. }
  129. // 获取配置的字体大小
  130. confName := models.FromSceneMap[fromScene]
  131. if confName != `` {
  132. busConf, err := models.GetBusinessConfByKey(confName)
  133. if err == nil {
  134. sizeDeci, err := decimal.NewFromString(busConf.ConfVal)
  135. if err == nil {
  136. config.FontSize = int(sizeDeci.IntPart())
  137. }
  138. }
  139. }
  140. resp.TableInfo = tableData
  141. resp.Source = excelInfo.Source
  142. resp.ExcelType = excelInfo.ExcelType
  143. resp.ExcelName = excelInfo.ExcelName
  144. resp.ExcelImage = excelInfo.ExcelImage
  145. resp.UniqueCode = excelInfo.UniqueCode
  146. resp.Config = config
  147. if utils.Re == nil {
  148. data, _ := json.Marshal(resp)
  149. utils.Rc.Put(key, data, 5*time.Minute)
  150. }
  151. br.Ret = 200
  152. br.Success = true
  153. br.Msg = "获取成功"
  154. br.Data = resp
  155. }