chart_info.go 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457
  1. package data
  2. import (
  3. "errors"
  4. "fmt"
  5. "hongze/hongze_chart_lib/models"
  6. "hongze/hongze_chart_lib/models/data_manage"
  7. "hongze/hongze_chart_lib/services/alarm_msg"
  8. "hongze/hongze_chart_lib/utils"
  9. "sort"
  10. "time"
  11. )
  12. // ChartInfoRefreshV1 图表刷新
  13. func ChartInfoRefreshV1(chartInfoId int) (err error) {
  14. var errmsg string
  15. defer func() {
  16. if err != nil {
  17. go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "ChartInfoRefresh:"+errmsg, utils.EmailSendToUsers)
  18. fmt.Println("ChartInfoRefresh Err:" + errmsg)
  19. }
  20. }()
  21. baseEdbInfoArr, calculateInfoArr, err := data_manage.GetChartInfoRefreshData(chartInfoId)
  22. if err != nil {
  23. errmsg = "获取需要刷新的指标失败:Err:" + err.Error()
  24. return
  25. }
  26. var startDate string
  27. newBaseEdbInfoArr := make([]*data_manage.EdbInfo, 0)
  28. baseMap := make(map[int]*data_manage.EdbInfo)
  29. for _, bv := range baseEdbInfoArr {
  30. // 如果不是普通指标,那么过滤
  31. if bv.EdbInfoType != 0 {
  32. continue
  33. }
  34. if _, ok := baseMap[bv.EdbInfoId]; !ok {
  35. newBaseEdbInfoArr = append(newBaseEdbInfoArr, bv)
  36. }
  37. baseMap[bv.EdbInfoId] = bv
  38. }
  39. fmt.Println("calculateInfoArr:", len(calculateInfoArr))
  40. newCalculateInfoArr := make([]*data_manage.EdbInfo, 0)
  41. calculateMap := make(map[int]*data_manage.EdbInfo)
  42. var calculateArr []int
  43. for _, bv := range calculateInfoArr {
  44. if _, ok := calculateMap[bv.EdbInfoId]; !ok {
  45. newCalculateInfoArr = append(newCalculateInfoArr, bv)
  46. calculateArr = append(calculateArr, bv.EdbInfoId)
  47. }
  48. calculateMap[bv.EdbInfoId] = bv
  49. }
  50. sort.Ints(calculateArr)
  51. for _, bv := range newBaseEdbInfoArr {
  52. source := bv.Source
  53. edbInfoId := bv.EdbInfoId
  54. edbCode := bv.EdbCode
  55. startDate = bv.StartDate
  56. frequency := bv.Frequency
  57. if bv.StartDate == "0000-00-00" {
  58. continue
  59. }
  60. sTime, err := time.Parse(utils.FormatDate, bv.EndDate)
  61. if err != nil {
  62. return err
  63. }
  64. var limitDay int
  65. startDate := ""
  66. switch frequency {
  67. case "日度":
  68. limitDay = utils.DATA_REFRESH
  69. case "周度":
  70. limitDay = utils.DATA_REFRESH * 7
  71. case "月度":
  72. limitDay = utils.DATA_REFRESH * 30
  73. case "季度":
  74. limitDay = utils.DATA_REFRESH * 90
  75. case "年度":
  76. limitDay = utils.DATA_REFRESH * 365
  77. default:
  78. limitDay = utils.DATA_REFRESH
  79. }
  80. startDate = sTime.AddDate(0, 0, -limitDay).Format(utils.FormatDate)
  81. fmt.Println("source:", source)
  82. respItem, err := RefreshEdbData(edbInfoId, source, edbCode, startDate)
  83. if err != nil {
  84. errmsg = errors.New("RefreshEdbData Err:" + err.Error()).Error()
  85. return err
  86. }
  87. if respItem.Ret != 200 {
  88. errmsg = errors.New(respItem.ErrMsg + ";EdbCode:" + edbCode).Error()
  89. return err
  90. }
  91. //maxAndMinItem, err := data_manage.GetEdbInfoMaxAndMinInfo(source, edbCode)
  92. //if err != nil {
  93. // return err
  94. //}
  95. //if maxAndMinItem != nil {
  96. // err = data_manage.ModifyEdbInfoMaxAndMinInfo(edbInfoId, maxAndMinItem)
  97. // if err != nil {
  98. // return err
  99. // }
  100. //}
  101. }
  102. //刷新相关计算指标
  103. for _, v := range calculateArr {
  104. edbInfo := calculateMap[v]
  105. if edbInfo == nil {
  106. return err
  107. }
  108. startDate = edbInfo.StartDate
  109. source := edbInfo.Source
  110. if source == utils.DATA_SOURCE_CALCULATE {
  111. startDate = edbInfo.StartDate
  112. sTime, err := time.Parse(utils.FormatDate, edbInfo.EndDate)
  113. if err != nil {
  114. return err
  115. }
  116. startDate = sTime.Format(utils.FormatDate)
  117. }
  118. result, err := RefreshEdbCalculateData(edbInfo.EdbInfoId, edbInfo.EdbCode, startDate)
  119. if err != nil {
  120. fmt.Println(v, "RefreshEdbCalculateData err", time.Now())
  121. errmsg = "RefreshEdbCalculateData Err:" + err.Error()
  122. return err
  123. }
  124. if result.Ret != 200 {
  125. fmt.Println(v, "RefreshEdbCalculateData err;msg:", result.Msg, ";errMsg:", result.ErrMsg)
  126. errmsg = fmt.Sprint(v, "RefreshEdbCalculateData err;msg:", result.Msg, ";errMsg:", result.ErrMsg)
  127. return fmt.Errorf("刷新失败" + errmsg)
  128. }
  129. fmt.Println("end calculateArr:", v, time.Now())
  130. }
  131. return err
  132. }
  133. // GetFrequencyEn 获取频度的英文版
  134. func GetFrequencyEn(frequency string) (frequencyEn string) {
  135. switch frequency {
  136. case "日度":
  137. frequencyEn = "day"
  138. return
  139. case "周度":
  140. frequencyEn = "week"
  141. return
  142. case "旬度":
  143. frequencyEn = "ten days"
  144. return
  145. case "月度":
  146. frequencyEn = "month"
  147. return
  148. case "季度":
  149. frequencyEn = "quarter"
  150. return
  151. case "年度":
  152. frequencyEn = "year"
  153. return
  154. }
  155. return
  156. }
  157. func GetLeadUnitEn(unit string) (unitEn string) {
  158. switch unit {
  159. case "天":
  160. unitEn = "day"
  161. return
  162. case "周":
  163. unitEn = "week"
  164. return
  165. case "月":
  166. unitEn = "month"
  167. return
  168. case "季":
  169. unitEn = "quarter"
  170. return
  171. case "年":
  172. unitEn = "year"
  173. return
  174. }
  175. return
  176. }
  177. // GetChartEdbData 获取图表的指标数据
  178. func GetChartEdbData(chartInfoId, chartType int, calendar, startDate, endDate string, mappingList []*models.ChartEdbInfoMapping) (edbList []*models.ChartEdbInfoMapping, err error) {
  179. edbList = make([]*models.ChartEdbInfoMapping, 0)
  180. for _, v := range mappingList {
  181. //fmt.Println("v:", v.EdbInfoId)
  182. item := new(models.ChartEdbInfoMapping)
  183. item.EdbInfoId = v.EdbInfoId
  184. item.SourceName = v.SourceName
  185. item.Source = v.Source
  186. item.EdbCode = v.EdbCode
  187. item.EdbName = v.EdbName
  188. item.EdbNameEn = v.EdbNameEn
  189. item.Frequency = v.Frequency
  190. item.FrequencyEn = GetFrequencyEn(v.Frequency)
  191. if v.Unit != `无` {
  192. item.Unit = v.Unit
  193. }
  194. item.UnitEn = v.UnitEn
  195. item.StartDate = v.StartDate
  196. item.EndDate = v.EndDate
  197. item.ModifyTime = v.ModifyTime
  198. item.EdbInfoCategoryType = v.EdbInfoCategoryType
  199. item.PredictChartColor = v.PredictChartColor
  200. if chartInfoId <= 0 {
  201. item.IsAxis = 1
  202. item.LeadValue = 0
  203. item.LeadUnit = ""
  204. //item.ChartEdbMappingId = 0
  205. item.ChartInfoId = 0
  206. item.IsOrder = false
  207. item.EdbInfoType = 1
  208. item.ChartStyle = ""
  209. item.ChartColor = ""
  210. item.ChartWidth = 0
  211. item.MaxData = v.MaxValue
  212. item.MinData = v.MinValue
  213. } else {
  214. item.IsAxis = v.IsAxis
  215. item.EdbInfoType = v.EdbInfoType
  216. item.LeadValue = v.LeadValue
  217. item.LeadUnit = v.LeadUnit
  218. item.LeadUnitEn = GetLeadUnitEn(v.LeadUnit)
  219. //item.ChartEdbMappingId = v.ChartEdbMappingId
  220. item.ChartInfoId = v.ChartInfoId
  221. item.ChartStyle = v.ChartStyle
  222. item.ChartColor = v.ChartColor
  223. item.ChartWidth = v.ChartWidth
  224. item.IsOrder = v.IsOrder
  225. item.MaxData = v.MaxData
  226. item.MinData = v.MinData
  227. }
  228. item.LatestValue = v.LatestValue
  229. item.LatestDate = v.LatestDate
  230. item.UniqueCode = v.UniqueCode
  231. var startDateReal string
  232. var diffSeconds int64
  233. if chartType == 2 { //季节性图
  234. startDateReal = startDate
  235. } else {
  236. if v.EdbInfoType == 0 && v.LeadUnit != "" && v.LeadValue > 0 { //领先指标
  237. var startTimeRealTemp time.Time
  238. startDateParse, _ := time.Parse(utils.FormatDate, startDate)
  239. switch v.LeadUnit {
  240. case "天":
  241. startTimeRealTemp = startDateParse.AddDate(0, 0, -v.LeadValue)
  242. case "月":
  243. startTimeRealTemp = startDateParse.AddDate(0, -v.LeadValue, 0)
  244. case "季":
  245. startTimeRealTemp = startDateParse.AddDate(0, -3*v.LeadValue, 0)
  246. case "周":
  247. startTimeRealTemp = startDateParse.AddDate(0, 0, -7*v.LeadValue)
  248. case "年":
  249. startTimeRealTemp = startDateParse.AddDate(-v.LeadValue, 0, 0)
  250. }
  251. if startTimeRealTemp.Before(startDateParse) {
  252. startDateReal = startTimeRealTemp.Format(utils.FormatDate)
  253. diffSeconds = (int64(startTimeRealTemp.UnixNano()) - int64(startDateParse.UnixNano())) / 1e6
  254. } else {
  255. startDateReal = startDate
  256. diffSeconds = 0
  257. }
  258. } else {
  259. startDateReal = startDate
  260. }
  261. }
  262. //fmt.Println("line 1011 chart:", v.Source, v.EdbInfoId, startDateReal, endDate)
  263. calendarPreYear := 0
  264. if calendar == "农历" {
  265. newStartDateReal, err := time.Parse(utils.FormatDate, startDateReal)
  266. if err != nil {
  267. fmt.Println("time.Parse:" + err.Error())
  268. }
  269. calendarPreYear = newStartDateReal.Year() - 1
  270. newStartDateReal = newStartDateReal.AddDate(-1, 0, 0)
  271. startDateReal = newStartDateReal.Format(utils.FormatDate)
  272. }
  273. dataList := make([]*models.EdbDataList, 0)
  274. //fmt.Println("chart:", v.Source, v.EdbInfoId, startDateReal, endDate)
  275. switch v.EdbInfoCategoryType {
  276. case 0:
  277. dataList, err = models.GetEdbDataList(v.Source, v.EdbInfoId, startDateReal, endDate)
  278. case 1:
  279. dataList, _, _, err, _ = GetPredictDataListByPredictEdbInfoId(v.EdbInfoId, startDateReal, endDate, false)
  280. default:
  281. err = errors.New(fmt.Sprint("获取失败,指标类型异常", v.EdbInfoCategoryType))
  282. }
  283. if err != nil {
  284. return
  285. }
  286. if diffSeconds != 0 && v.EdbInfoType == 0 {
  287. dataListLen := len(dataList)
  288. for i := 0; i < dataListLen; i++ {
  289. dataList[i].DataTimestamp = dataList[i].DataTimestamp - diffSeconds
  290. }
  291. }
  292. if chartType == 2 {
  293. latestDateStr := v.LatestDate //实际数据的截止日期
  294. latestDate, tmpErr := time.Parse(utils.FormatDate, v.LatestDate)
  295. if tmpErr != nil {
  296. err = errors.New(fmt.Sprint("获取最后实际数据的日期失败,Err:" + tmpErr.Error() + ";LatestDate:" + v.LatestDate))
  297. return
  298. }
  299. latestDateYear := latestDate.Year() //实际数据截止年份
  300. if calendar == "农历" {
  301. if len(dataList) <= 0 {
  302. result := new(models.EdbDataResult)
  303. item.DataList = result
  304. } else {
  305. result, tmpErr := models.AddCalculateQuarterV5(dataList)
  306. if tmpErr != nil {
  307. err = errors.New("获取农历数据失败,Err:" + tmpErr.Error())
  308. return
  309. }
  310. // 处理季节图的截止日期
  311. for k, edbDataItems := range result.List {
  312. var cuttingDataTimestamp int64
  313. // 切割的日期时间字符串
  314. cuttingDataTimeStr := latestDate.AddDate(0, 0, edbDataItems.BetweenDay).Format(utils.FormatDate)
  315. //如果等于最后的实际日期,那么遍历找到该日期对应的时间戳,并将其赋值为 切割时间戳
  316. if edbDataItems.Year >= latestDateYear {
  317. for _, tmpData := range edbDataItems.Items {
  318. if tmpData.DataTime == cuttingDataTimeStr {
  319. cuttingDataTimestamp = tmpData.DataTimestamp
  320. break
  321. }
  322. }
  323. }
  324. edbDataItems.CuttingDataTimestamp = cuttingDataTimestamp
  325. result.List[k] = edbDataItems
  326. }
  327. if result.List[0].Year != calendarPreYear {
  328. itemList := make([]*models.EdbDataList, 0)
  329. items := new(models.EdbDataItems)
  330. //items.Year = calendarPreYear
  331. items.Items = itemList
  332. newResult := new(models.EdbDataResult)
  333. newResult.List = append(newResult.List, items)
  334. newResult.List = append(newResult.List, result.List...)
  335. item.DataList = newResult
  336. } else {
  337. item.DataList = result
  338. }
  339. }
  340. } else {
  341. currentYear := time.Now().Year()
  342. quarterDataList := make([]*models.QuarterData, 0)
  343. quarterMap := make(map[int][]*models.EdbDataList)
  344. var quarterArr []int
  345. for _, v := range dataList {
  346. itemDate, tmpErr := time.Parse(utils.FormatDate, v.DataTime)
  347. if tmpErr != nil {
  348. err = errors.New("季度指标日期转换,Err:" + tmpErr.Error() + ";DataTime:" + v.DataTime)
  349. return
  350. }
  351. year := itemDate.Year()
  352. newItemDate := itemDate.AddDate(currentYear-year, 0, 0)
  353. timestamp := newItemDate.UnixNano() / 1e6
  354. v.DataTimestamp = timestamp
  355. if findVal, ok := quarterMap[year]; !ok {
  356. quarterArr = append(quarterArr, year)
  357. findVal = append(findVal, v)
  358. quarterMap[year] = findVal
  359. } else {
  360. findVal = append(findVal, v)
  361. quarterMap[year] = findVal
  362. }
  363. }
  364. for _, v := range quarterArr {
  365. itemList := quarterMap[v]
  366. quarterItem := new(models.QuarterData)
  367. quarterItem.Year = v
  368. quarterItem.DataList = itemList
  369. //如果等于最后的实际日期,那么将切割时间戳记录
  370. if v == latestDateYear {
  371. var cuttingDataTimestamp int64
  372. for _, tmpData := range itemList {
  373. if tmpData.DataTime == latestDateStr {
  374. cuttingDataTimestamp = tmpData.DataTimestamp
  375. break
  376. }
  377. }
  378. quarterItem.CuttingDataTimestamp = cuttingDataTimestamp
  379. } else if v > latestDateYear {
  380. //如果大于最后的实际日期,那么第一个点就是切割的时间戳
  381. if len(itemList) > 0 {
  382. quarterItem.CuttingDataTimestamp = itemList[0].DataTimestamp - 100
  383. }
  384. }
  385. quarterDataList = append(quarterDataList, quarterItem)
  386. }
  387. item.DataList = quarterDataList
  388. }
  389. } else {
  390. item.DataList = dataList
  391. }
  392. edbList = append(edbList, item)
  393. }
  394. return
  395. }
  396. // ChartInfoRefreshV2 图表刷新
  397. // @author Roc
  398. // @datetime 2022-09-16 10:15:38
  399. // @description 将原来自己写的一套获取所有关联指标,然后刷新指标逻辑 改成 只获取使用的指标id,然后遍历去调用“指标刷新服务”
  400. func ChartInfoRefreshV2(chartInfoId int) (err error) {
  401. var errmsg string
  402. defer func() {
  403. if err != nil {
  404. go alarm_msg.SendAlarmMsg("ChartInfoRefresh:"+errmsg, 3)
  405. //go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "ChartInfoRefresh:"+errmsg, utils.EmailSendToUsers)
  406. fmt.Println("ChartInfoRefresh Err:" + errmsg)
  407. }
  408. }()
  409. edbMappingList, err := data_manage.GetChartEdbMappingList(chartInfoId)
  410. if err != nil {
  411. errmsg = "获取需要刷新的指标失败:Err:" + err.Error()
  412. return
  413. }
  414. edbIdList := make([]int, 0)
  415. for _, v := range edbMappingList {
  416. edbIdList = append(edbIdList, v.EdbInfoId)
  417. }
  418. // 批量刷新
  419. err = EdbInfoRefreshAllFromBase(edbIdList, false)
  420. if err != nil {
  421. return
  422. }
  423. return
  424. }