base_from_clarksons.go 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "eta/eta_index_lib/logic"
  5. "eta/eta_index_lib/models"
  6. "eta/eta_index_lib/utils"
  7. "fmt"
  8. "strconv"
  9. "strings"
  10. "time"
  11. )
  12. type ClarksonsDataController struct {
  13. BaseAuthController
  14. }
  15. // @Title 克拉克森
  16. // @Description 刷新克拉克森数据接口
  17. // @Param request body models.CoalMineDataReq true "type json string"
  18. // @Success 200 {object} models.EdbClassify
  19. // @router /data [post]
  20. func (this *ClarksonsDataController) ClarksonsData() {
  21. br := new(models.BaseResponse).Init()
  22. defer func() {
  23. this.Data["json"] = br
  24. this.ServeJSON()
  25. }()
  26. var req models.CoalMineDataReq
  27. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  28. if err != nil {
  29. br.Msg = "参数解析异常!"
  30. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  31. return
  32. }
  33. var dateMap = make(map[int]time.Time)
  34. var indexMap = make(map[string]*models.BaseFromClarksonsIndex)
  35. //var indexMap = make(map[string]string)
  36. var itemsIndex []*models.BaseFromClarksonsData
  37. codeList, err := models.GetBaseFromClarksonsIndex()
  38. if err != nil && err.Error() != utils.ErrNoRow() {
  39. utils.FileLog.Info("获取克拉克森指标失败:", err)
  40. return
  41. }
  42. if len(codeList) > 0 {
  43. for _, v := range codeList {
  44. indexMap[v.IndexCode] = v
  45. }
  46. }
  47. for _, sheet := range req.SheetData {
  48. //遍历行读取
  49. maxRow := sheet.MaxRow
  50. maxCol := sheet.MaxCol
  51. for j := 1; j < maxCol; j++ {
  52. var indexId int64
  53. index := new(models.BaseFromClarksonsIndex)
  54. indexCode := ""
  55. for i := 3; i < maxRow; i++ {
  56. //获取样本情况
  57. row := sheet.Rows[i]
  58. cells := row.Cells
  59. if j == 0 {
  60. continue
  61. }
  62. // indexCode
  63. if i == 3 {
  64. indexCode = cells[j].Value
  65. continue
  66. }
  67. if indexItem, ok := indexMap[indexCode]; !ok {
  68. // indexName
  69. if i == 4 {
  70. index.IndexName = cells[j].Value
  71. continue
  72. }
  73. // unit
  74. if i == 5 {
  75. index.Unit = cells[j].Value
  76. continue
  77. }
  78. index.IndexCode = indexCode
  79. index.CreateTime = time.Now()
  80. index.ModifyTime = time.Now()
  81. indexId, err = models.AddBaseFromClarksonsIndex(index)
  82. if err != nil {
  83. utils.FileLog.Info("添加指标名称错误", err.Error())
  84. fmt.Println("添加指标名称错误", err.Error())
  85. return
  86. }
  87. index.BaseFromClarksonsIndexId = int(indexId)
  88. indexMap[indexCode] = index
  89. } else {
  90. index = indexItem
  91. }
  92. // 数据及日期
  93. if i > 5 {
  94. var date time.Time
  95. if len(cells) == 0 {
  96. break
  97. }
  98. for k, cell := range cells {
  99. text := cell.Value
  100. text = strings.Replace(text, "\\", "", -1)
  101. if text != "" {
  102. // 时间
  103. if k == 0 {
  104. if text != "" {
  105. dataTime, err := utils.ParseDateTime(text)
  106. if err != nil {
  107. utils.FileLog.Info("解析时间字符串出错:", err)
  108. fmt.Println("解析时间字符串出错:", err)
  109. return
  110. }
  111. //date = dataTime.Format(utils.FormatDate)
  112. date = dataTime
  113. }
  114. dateMap[k] = date
  115. }
  116. // 数据
  117. if k == j {
  118. item := new(models.BaseFromClarksonsData)
  119. item.IndexCode = indexCode
  120. item.Value = text
  121. item.DataTime = date
  122. item.BaseFromClarksonsIndexId = index.BaseFromClarksonsIndexId
  123. item.ModifyTime = time.Now()
  124. item.CreateTime = time.Now()
  125. itemsIndex = append(itemsIndex, item)
  126. continue
  127. }
  128. }
  129. }
  130. }
  131. }
  132. if len(itemsIndex) > 2 {
  133. //time1, _ := time.Parse(utils.FormatDate, itemsIndex[0].DataTime)
  134. //time2, _ := time.Parse(utils.FormatDate, itemsIndex[1].DataTime)
  135. time1 := itemsIndex[0].DataTime
  136. time2 := itemsIndex[1].DataTime
  137. diff := time2.Sub(time1).Hours() / 24
  138. if diff < 5 {
  139. index.Frequency = "日度"
  140. } else if diff > 5 && diff < 10 {
  141. index.Frequency = "周度"
  142. } else if diff > 20 && diff < 50 {
  143. index.Frequency = "月度"
  144. } else if diff > 50 && diff < 100 {
  145. index.Frequency = "季度"
  146. } else if diff > 100 {
  147. index.Frequency = "年度"
  148. }
  149. }
  150. err = models.UpdateBaseFromClarksonsIndex(index)
  151. if err != nil {
  152. fmt.Println("修改指标频度错误", err)
  153. utils.FileLog.Info("修改指标频度错误", err)
  154. return
  155. } else {
  156. fmt.Println("修改指标频度成功 ", index.IndexCode, index.Frequency)
  157. utils.FileLog.Info("修改指标频度成功 ", index.IndexCode, index.Frequency)
  158. }
  159. }
  160. }
  161. count, err := models.AddBaseFromClarksonsDataMuti(itemsIndex)
  162. if err != nil {
  163. fmt.Println("添加数据错误", err.Error())
  164. utils.FileLog.Info("添加数据错误", err)
  165. } else {
  166. fmt.Println("添加数据成功", count)
  167. utils.FileLog.Info("添加数据成功", count)
  168. }
  169. fmt.Println("数据操作完成")
  170. utils.FileLog.Info("数据操作完成")
  171. br.Ret = 200
  172. br.Success = true
  173. br.Msg = "获取成功"
  174. return
  175. }
  176. // @Title 新增克拉克森指标接口
  177. // @Description 新增克拉克森指标接口
  178. // @Success 200 {object} models.AddEdbInfoReq
  179. // @router /add [post]
  180. func (this *ClarksonsDataController) Add() {
  181. br := new(models.BaseResponse).Init()
  182. var cacheKey string
  183. defer func() {
  184. utils.Rc.Delete(cacheKey)
  185. this.Data["json"] = br
  186. this.ServeJSON()
  187. }()
  188. source := utils.DATA_SOURCE_CLARKSONS
  189. var req models.AddEdbInfoReq
  190. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  191. if err != nil {
  192. br.Msg = "参数解析异常!"
  193. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  194. return
  195. }
  196. if req.EdbCode == "" {
  197. br.Msg = "请输入指标编码!"
  198. br.ErrMsg = "请输入指标编码,指标编码为空"
  199. return
  200. }
  201. cacheKey = utils.CACHE_EDB_DATA_ADD + strconv.Itoa(source) + "_" + req.EdbCode
  202. if !utils.Rc.IsExist(cacheKey) {
  203. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  204. err = models.AddEdbDataFromClarksons(req.EdbCode)
  205. if err != nil {
  206. br.Msg = "获取指标信息失败!"
  207. br.ErrMsg = "获取指标信息失败 AddEdbDataFromClarksons,Err:" + err.Error()
  208. return
  209. }
  210. br.Ret = 200
  211. br.Success = true
  212. br.Msg = "获取成功"
  213. } else {
  214. br.Ret = 501
  215. br.Success = true
  216. br.Msg = "系统处理中,请稍后重试"
  217. }
  218. }
  219. // @Title 刷新克拉克森指标接口
  220. // @Description 刷新克拉克森指标接口
  221. // @Success 200 {object} models.RefreshEdbInfoReq
  222. // @router /refresh [post]
  223. func (this *ClarksonsDataController) Refresh() {
  224. br := new(models.BaseResponse).Init()
  225. var cacheKey string
  226. defer func() {
  227. utils.Rc.Delete(cacheKey)
  228. this.Data["json"] = br
  229. this.ServeJSON()
  230. }()
  231. source := utils.DATA_SOURCE_CLARKSONS
  232. var req models.RefreshEdbInfoReq
  233. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  234. if err != nil {
  235. br.Msg = "参数解析异常!"
  236. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  237. return
  238. }
  239. if req.EdbCode == "" {
  240. br.Msg = "请输入指标编码!"
  241. br.ErrMsg = "请输入指标编码,指标编码为空"
  242. return
  243. }
  244. if req.EdbInfoId <= 0 {
  245. br.Msg = "请输入指标ID!"
  246. br.ErrMsg = "请输入指标ID"
  247. return
  248. }
  249. cacheKey = utils.CACHE_EDB_DATA_REFRESH + strconv.Itoa(source) + "_" + req.EdbCode
  250. if utils.Rc.IsExist(cacheKey) {
  251. br.Ret = 501
  252. br.Success = true
  253. br.Msg = "系统处理中,请稍后重试"
  254. return
  255. }
  256. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  257. // 获取指标详情
  258. edbInfo, err := models.GetEdbInfoById(req.EdbInfoId)
  259. if err != nil {
  260. br.Msg = "指标不存在!"
  261. br.ErrMsg = "指标不存在"
  262. return
  263. }
  264. err = models.RefreshEdbDataFromClarksons(req.EdbInfoId, req.EdbCode, req.StartDate)
  265. if err != nil && err.Error() != utils.ErrNoRow() {
  266. br.Msg = "刷新指标信息失败!"
  267. br.ErrMsg = "刷新指标信息失败 RefreshEdbDataFromCoal,Err:" + err.Error()
  268. return
  269. }
  270. // 更新指标最大最小值
  271. err, errMsg := models.UnifiedModifyEdbInfoMaxAndMinInfo(edbInfo)
  272. if err != nil {
  273. br.Msg = errMsg
  274. br.ErrMsg = err.Error()
  275. return
  276. }
  277. // 更新ES
  278. go logic.UpdateEs(edbInfo.EdbInfoId)
  279. br.Ret = 200
  280. br.Success = true
  281. br.Msg = "获取成功"
  282. }