chart_info.go 12 KB

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