excel_info.go 5.2 KB

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