chart_info.go 68 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194
  1. package range_analysis
  2. import (
  3. "encoding/json"
  4. "errors"
  5. "eta/eta_api/models/data_manage"
  6. "eta/eta_api/models/system"
  7. "eta/eta_api/services/alarm_msg"
  8. "eta/eta_api/services/data"
  9. "eta/eta_api/utils"
  10. "fmt"
  11. "github.com/shopspring/decimal"
  12. "math"
  13. "sort"
  14. "strconv"
  15. "strings"
  16. "time"
  17. )
  18. // GetAutoCalculateDateDataList 获取当前时间相关的区间作为计算依据
  19. func GetAutoCalculateDateDataList(currentDate string, dataList []*data_manage.EdbDataList, req *data_manage.ChartRangeAnalysisExtraConf) (newDataList []*data_manage.EdbDataList, err error) {
  20. currentDateTime, _ := time.ParseInLocation(utils.FormatDate, currentDate, time.Local)
  21. switch req.DateRangeType {
  22. case 0:
  23. // 智能划分得到一个开始日期,和结束日期
  24. var startDateTime time.Time
  25. if req.AutoDateConf.IsAutoStartDate == 0 { //固定设置
  26. startDate := req.AutoDateConf.StartDate
  27. if startDate == "" {
  28. startDate = "2020-01-01"
  29. }
  30. startDateTime, _ = time.ParseInLocation(utils.FormatDate, startDate, time.Local)
  31. } else {
  32. startConf := req.AutoDateConf.StartDateConf
  33. startDate := ""
  34. if startConf.BaseDateType == 0 { //
  35. startDate = currentDate
  36. } else if startConf.BaseDateType == 1 {
  37. startDate = time.Now().Format(utils.FormatDate)
  38. }
  39. if startConf.MoveForward > 0 {
  40. startDate = GetEdbDateByMoveForward(startDate, startConf.MoveForward, dataList)
  41. }
  42. if len(startConf.DateChange) > 0 {
  43. startDate, err = HandleEdbDateChange(startDate, startConf.DateChange)
  44. if err != nil {
  45. err = fmt.Errorf("智能划分开始日期处理失败:%s", err.Error())
  46. return
  47. }
  48. }
  49. startDateTime, _ = time.ParseInLocation(utils.FormatDate, startDate, time.Local)
  50. }
  51. var calStartTime, calEndTime time.Time
  52. if currentDateTime.Before(startDateTime) {
  53. calStartTime = currentDateTime
  54. calEndTime = startDateTime
  55. } else {
  56. calStartTime = startDateTime
  57. calEndTime = currentDateTime
  58. }
  59. // 根据日期,获取数据
  60. for _, vv := range dataList {
  61. dataTimeT, _ := time.ParseInLocation(utils.FormatDate, vv.DataTime, time.Local)
  62. if dataTimeT.After(calStartTime) && dataTimeT.Before(calEndTime) ||
  63. dataTimeT.Equal(calStartTime) ||
  64. dataTimeT.Equal(calEndTime) {
  65. newDataList = append(newDataList, vv)
  66. }
  67. }
  68. }
  69. return
  70. }
  71. // HandleDataByCalculateType 根据计算公式处理数据
  72. func HandleDataByCalculateType(originList []*data_manage.ChartRangeAnalysisDateDataItem, originDataList []*data_manage.EdbDataList, req *data_manage.ChartRangeAnalysisExtraConf) (newList []*data_manage.EdbDataList, err error) {
  73. if len(originList) == 0 {
  74. return
  75. }
  76. calculateType := req.CalculateType
  77. switch calculateType {
  78. case 0: //均值
  79. var sum float64
  80. if req.DateRangeType == 0 {
  81. for _, item := range originList {
  82. for _, v := range item.DataList {
  83. sum = 0
  84. //计算的数据返回需要重新确定
  85. calDataList, e := GetAutoCalculateDateDataList(v.DataTime, originDataList, req)
  86. if e != nil {
  87. err = fmt.Errorf("获取区间数据失败:%s", e.Error())
  88. return
  89. }
  90. for _, vv := range calDataList {
  91. sum += vv.Value
  92. }
  93. val := sum / float64(len(calDataList))
  94. val, _ = decimal.NewFromFloat(val).Round(4).Float64()
  95. newList = append(newList, &data_manage.EdbDataList{
  96. DataTime: v.DataTime,
  97. Value: val,
  98. DataTimestamp: v.DataTimestamp,
  99. })
  100. }
  101. }
  102. } else {
  103. for _, item := range originList {
  104. sum = 0
  105. for k, v := range item.DataList {
  106. sum += v.Value
  107. val := sum / float64(k+1)
  108. val, _ = decimal.NewFromFloat(val).Round(4).Float64()
  109. newList = append(newList, &data_manage.EdbDataList{
  110. DataTime: v.DataTime,
  111. Value: val,
  112. DataTimestamp: v.DataTimestamp,
  113. })
  114. }
  115. }
  116. }
  117. case 1: //累计值
  118. var sum float64
  119. if req.DateRangeType == 0 {
  120. for _, item := range originList {
  121. sum = 0
  122. for _, v := range item.DataList {
  123. sum = 0
  124. //计算的数据返回需要重新确定
  125. calDataList, e := GetAutoCalculateDateDataList(v.DataTime, originDataList, req)
  126. if e != nil {
  127. err = fmt.Errorf("获取区间数据失败:%s", e.Error())
  128. return
  129. }
  130. for _, vv := range calDataList {
  131. sum += vv.Value
  132. }
  133. val := sum
  134. val, _ = decimal.NewFromFloat(val).Round(4).Float64()
  135. newList = append(newList, &data_manage.EdbDataList{
  136. DataTime: v.DataTime,
  137. Value: val,
  138. DataTimestamp: v.DataTimestamp,
  139. })
  140. }
  141. }
  142. } else {
  143. for _, item := range originList {
  144. sum = 0
  145. for _, v := range item.DataList {
  146. sum += v.Value
  147. val := sum
  148. val, _ = decimal.NewFromFloat(val).Round(4).Float64()
  149. newList = append(newList, &data_manage.EdbDataList{
  150. DataTime: v.DataTime,
  151. Value: val,
  152. DataTimestamp: v.DataTimestamp,
  153. })
  154. }
  155. }
  156. }
  157. case 2: //涨幅
  158. if req.DateRangeType == 0 {
  159. for _, item := range originList {
  160. for _, v := range item.DataList {
  161. var baseVal float64
  162. //计算的数据返回需要重新确定
  163. calDataList, e := GetAutoCalculateDateDataList(v.DataTime, originDataList, req)
  164. if e != nil {
  165. err = fmt.Errorf("获取区间数据失败:%s", e.Error())
  166. return
  167. }
  168. if len(calDataList) == 0 {
  169. continue
  170. }
  171. baseVal = calDataList[len(calDataList)-1].Value
  172. if baseVal == 0 {
  173. continue
  174. }
  175. val := (v.Value - baseVal) / baseVal
  176. val, _ = decimal.NewFromFloat(val).Round(4).Float64()
  177. newList = append(newList, &data_manage.EdbDataList{
  178. DataTime: v.DataTime,
  179. Value: val,
  180. DataTimestamp: v.DataTimestamp,
  181. })
  182. }
  183. }
  184. } else {
  185. for _, item := range originList {
  186. var baseVal float64
  187. for k, v := range item.DataList {
  188. if k == 0 {
  189. baseVal = v.Value
  190. if baseVal == 0 {
  191. break
  192. }
  193. }
  194. val := (v.Value - baseVal) / baseVal
  195. val, _ = decimal.NewFromFloat(val).Round(4).Float64()
  196. newList = append(newList, &data_manage.EdbDataList{
  197. DataTime: v.DataTime,
  198. Value: val,
  199. DataTimestamp: v.DataTimestamp,
  200. })
  201. }
  202. }
  203. }
  204. case 3: //复合增长率
  205. if req.DateRangeType == 0 {
  206. for _, item := range originList {
  207. for _, v := range item.DataList {
  208. var baseVal float64
  209. var baseDate string
  210. calDataList, e := GetAutoCalculateDateDataList(v.DataTime, originDataList, req)
  211. if e != nil {
  212. err = fmt.Errorf("获取区间数据失败:%s", e.Error())
  213. return
  214. }
  215. if len(calDataList) == 0 {
  216. continue
  217. }
  218. baseVal = calDataList[len(calDataList)-1].Value
  219. baseDate = calDataList[len(calDataList)-1].DataTime
  220. if v.DataTime == baseDate {
  221. continue
  222. }
  223. if baseVal == 0 {
  224. continue
  225. }
  226. baseDateT, e := time.ParseInLocation(utils.FormatDate, baseDate, time.Local)
  227. if e != nil {
  228. err = fmt.Errorf("time.ParseInLocation err: %v", e)
  229. return
  230. }
  231. tmpT, e := time.ParseInLocation(utils.FormatDate, v.DataTime, time.Local)
  232. if e != nil {
  233. err = fmt.Errorf("time.ParseInLocation err: %v", e)
  234. return
  235. }
  236. // 计算两个日期相差的天数
  237. diff := tmpT.Sub(baseDateT).Hours() / 24 / 365
  238. val := v.Value / baseVal
  239. val = math.Pow(val, 1/diff) - 1
  240. val, _ = decimal.NewFromFloat(val).Round(4).Float64()
  241. newList = append(newList, &data_manage.EdbDataList{DataTime: v.DataTime, Value: val, DataTimestamp: v.DataTimestamp})
  242. }
  243. }
  244. } else {
  245. for _, item := range originList {
  246. var baseVal float64
  247. var baseDate string
  248. for k, v := range item.DataList {
  249. if k == 0 {
  250. baseVal = v.Value
  251. baseDate = v.DataTime
  252. if baseVal == 0 {
  253. break
  254. }
  255. continue
  256. }
  257. baseDateT, e := time.ParseInLocation(utils.FormatDate, baseDate, time.Local)
  258. if e != nil {
  259. err = fmt.Errorf("time.ParseInLocation err: %v", e)
  260. return
  261. }
  262. tmpT, e := time.ParseInLocation(utils.FormatDate, v.DataTime, time.Local)
  263. if e != nil {
  264. err = fmt.Errorf("time.ParseInLocation err: %v", e)
  265. return
  266. }
  267. // 计算两个日期相差的天数
  268. diff := tmpT.Sub(baseDateT).Hours() / 24 / 365
  269. val := v.Value / baseVal
  270. val = math.Pow(val, 1/diff) - 1
  271. val, _ = decimal.NewFromFloat(val).Round(4).Float64()
  272. newList = append(newList, &data_manage.EdbDataList{DataTime: v.DataTime, Value: val, DataTimestamp: v.DataTimestamp})
  273. }
  274. }
  275. }
  276. case 4: //最大值
  277. var maxVal float64
  278. if req.DateRangeType == 0 {
  279. for _, item := range originList {
  280. for _, v := range item.DataList {
  281. calDataList, e := GetAutoCalculateDateDataList(v.DataTime, originDataList, req)
  282. if e != nil {
  283. err = fmt.Errorf("获取区间数据失败:%s", e.Error())
  284. return
  285. }
  286. for kk, vv := range calDataList {
  287. if kk == 0 {
  288. maxVal = vv.Value
  289. }
  290. if vv.Value > maxVal {
  291. maxVal = vv.Value
  292. }
  293. }
  294. val := maxVal
  295. val, _ = decimal.NewFromFloat(val).Round(4).Float64()
  296. newList = append(newList, &data_manage.EdbDataList{DataTime: v.DataTime, Value: val, DataTimestamp: v.DataTimestamp})
  297. }
  298. }
  299. } else {
  300. for _, item := range originList {
  301. for k, v := range item.DataList {
  302. if k == 0 {
  303. maxVal = v.Value
  304. }
  305. if v.Value > maxVal {
  306. maxVal = v.Value
  307. }
  308. val := maxVal
  309. val, _ = decimal.NewFromFloat(val).Round(4).Float64()
  310. newList = append(newList, &data_manage.EdbDataList{DataTime: v.DataTime, Value: val, DataTimestamp: v.DataTimestamp})
  311. }
  312. }
  313. }
  314. case 5: //最小值
  315. var minVal float64
  316. if req.DateRangeType == 0 {
  317. for _, item := range originList {
  318. for _, v := range item.DataList {
  319. calDataList, e := GetAutoCalculateDateDataList(v.DataTime, originDataList, req)
  320. if e != nil {
  321. err = fmt.Errorf("获取区间数据失败:%s", e.Error())
  322. return
  323. }
  324. for kk, vv := range calDataList {
  325. if kk == 0 {
  326. minVal = vv.Value
  327. }
  328. if vv.Value < minVal {
  329. minVal = vv.Value
  330. }
  331. }
  332. val := minVal
  333. val, _ = decimal.NewFromFloat(val).Round(4).Float64()
  334. newList = append(newList, &data_manage.EdbDataList{DataTime: v.DataTime, Value: val, DataTimestamp: v.DataTimestamp})
  335. }
  336. }
  337. } else {
  338. for _, item := range originList {
  339. for k, v := range item.DataList {
  340. if k == 0 {
  341. minVal = v.Value
  342. }
  343. if v.Value < minVal {
  344. minVal = v.Value
  345. }
  346. val := minVal
  347. val, _ = decimal.NewFromFloat(val).Round(4).Float64()
  348. newList = append(newList, &data_manage.EdbDataList{DataTime: v.DataTime, Value: val, DataTimestamp: v.DataTimestamp})
  349. }
  350. }
  351. }
  352. }
  353. return
  354. }
  355. // MoveDataDaysToNewDataList 平移指标数据生成新的数据序列
  356. func MoveDataDaysToNewDataList(dataList []*data_manage.EdbDataList, moveDay int) (newDataList []data_manage.EdbDataList, dateDataMap map[string]float64) {
  357. dateMap := make(map[time.Time]float64)
  358. var minDate, maxDate time.Time
  359. dateDataMap = make(map[string]float64)
  360. for _, v := range dataList {
  361. currDate, _ := time.ParseInLocation(utils.FormatDate, v.DataTime, time.Local)
  362. if minDate.IsZero() || currDate.Before(minDate) {
  363. minDate = currDate
  364. }
  365. if maxDate.IsZero() || currDate.After(maxDate) {
  366. maxDate = currDate
  367. }
  368. dateMap[currDate] = v.Value
  369. }
  370. // 处理领先、滞后数据
  371. newDateMap := make(map[time.Time]float64)
  372. for currDate, value := range dateMap {
  373. newDate := currDate.AddDate(0, 0, moveDay)
  374. newDateMap[newDate] = value
  375. }
  376. minDate = minDate.AddDate(0, 0, moveDay)
  377. maxDate = maxDate.AddDate(0, 0, moveDay)
  378. // 获取日期相差日
  379. dayNum := utils.GetTimeSubDay(minDate, maxDate)
  380. for i := 0; i <= dayNum; i++ {
  381. currDate := minDate.AddDate(0, 0, i)
  382. tmpValue, ok := newDateMap[currDate]
  383. if !ok {
  384. //找不到数据,那么就用前面的数据吧
  385. if len(newDataList)-1 < 0 {
  386. tmpValue = 0
  387. } else {
  388. tmpValue = newDataList[len(newDataList)-1].Value
  389. }
  390. }
  391. tmpData := data_manage.EdbDataList{
  392. DataTime: currDate.Format(utils.FormatDate),
  393. Value: tmpValue,
  394. }
  395. dateDataMap[tmpData.DataTime] = tmpData.Value
  396. newDataList = append(newDataList, tmpData)
  397. }
  398. return
  399. }
  400. // GetChartEdbInfoFormat 区间计算图表-获取指标信息
  401. func GetChartEdbInfoFormat(chartInfoId int, edbInfoMappingList []*data_manage.ChartEdbInfoMapping) (edbList []*data_manage.ChartEdbInfoMapping, err error) {
  402. edbList = make([]*data_manage.ChartEdbInfoMapping, 0)
  403. for _, edbInfoMapping := range edbInfoMappingList {
  404. if edbInfoMapping == nil {
  405. err = fmt.Errorf("指标信息有误")
  406. return
  407. }
  408. edbInfoMapping.FrequencyEn = data.GetFrequencyEn(edbInfoMapping.Frequency)
  409. if edbInfoMapping.Unit == `无` {
  410. edbInfoMapping.Unit = ``
  411. }
  412. if chartInfoId <= 0 {
  413. edbInfoMapping.IsAxis = 1
  414. edbInfoMapping.LeadValue = 0
  415. edbInfoMapping.LeadUnit = ""
  416. edbInfoMapping.ChartEdbMappingId = 0
  417. edbInfoMapping.ChartInfoId = 0
  418. edbInfoMapping.IsOrder = false
  419. edbInfoMapping.EdbInfoType = 1
  420. edbInfoMapping.ChartStyle = ""
  421. edbInfoMapping.ChartColor = ""
  422. edbInfoMapping.ChartWidth = 0
  423. } else {
  424. edbInfoMapping.LeadUnitEn = data.GetLeadUnitEn(edbInfoMapping.LeadUnit)
  425. }
  426. edbList = append(edbList, edbInfoMapping)
  427. }
  428. return
  429. }
  430. // GetChartDataByEdbInfoList 区间计算图表-根据指标信息获取x轴和y轴
  431. func GetChartDataByEdbInfoList(chartInfoId int, dateType, startYear int, startDate, endDate string, edbInfoMappingList []*data_manage.ChartEdbInfoMapping, req *data_manage.ChartRangeAnalysisExtraConf) (edbList []*data_manage.ChartEdbInfoMapping, xEdbIdValue []int, dataResp data_manage.ChartRangeAnalysisDataResp, err error) {
  432. if chartInfoId > 0 && req.EdbInfoMode == 1 {
  433. edbList, xEdbIdValue, dataResp, err = GetChartDataByEdbInfoListBySeries(chartInfoId, dateType, startYear, startDate, endDate, edbInfoMappingList, req)
  434. return
  435. }
  436. for _, edbInfoMapping := range edbInfoMappingList {
  437. edbInfoMapping, err = getChartDataByEdbInfo(edbInfoMapping, req)
  438. if err != nil {
  439. return
  440. }
  441. if req.CalculateType == 2 || req.CalculateType == 3 {
  442. edbInfoMapping.Unit = "无"
  443. edbInfoMapping.UnitEn = "无"
  444. }
  445. dataList := edbInfoMapping.DataList.([]*data_manage.EdbDataList)
  446. // 处理上下限
  447. var maxData, minData float64
  448. if len(dataList) > 0 {
  449. maxData = dataList[0].Value
  450. minData = dataList[0].Value
  451. for _, v := range dataList {
  452. if v.Value > maxData {
  453. maxData = v.Value
  454. }
  455. if v.Value < minData {
  456. minData = v.Value
  457. }
  458. }
  459. }
  460. edbInfoMapping.MaxData = maxData
  461. edbInfoMapping.MinData = minData
  462. xEdbIdValue = append(xEdbIdValue, edbInfoMapping.EdbInfoId)
  463. }
  464. //根据时间类型来筛选最终的数据
  465. yearMax := 0
  466. if dateType == utils.DateTypeNYears {
  467. for _, v := range edbInfoMappingList {
  468. dataList := v.DataList.([]*data_manage.EdbDataList)
  469. if len(dataList) > 0 {
  470. latestDate := dataList[0].DataTime
  471. if latestDate != "" {
  472. lastDateT, tErr := time.Parse(utils.FormatDate, latestDate)
  473. if tErr != nil {
  474. err = fmt.Errorf("获取图表日期信息失败,Err:" + tErr.Error())
  475. return
  476. }
  477. if lastDateT.Year() > yearMax {
  478. yearMax = lastDateT.Year()
  479. }
  480. }
  481. }
  482. }
  483. }
  484. startDate, endDate = utils.GetDateByDateTypeV2(dateType, startDate, endDate, startYear, yearMax)
  485. if startDate != "" {
  486. for k, v := range edbInfoMappingList {
  487. var maxData, minData float64
  488. dataList := v.DataList.([]*data_manage.EdbDataList)
  489. newDataList := make([]*data_manage.EdbDataList, 0)
  490. if len(dataList) == 0 {
  491. newDataList = dataList
  492. } else {
  493. firstFlag := true
  494. for _, d := range dataList {
  495. if endDate != "" && d.DataTime > endDate {
  496. continue
  497. }
  498. if d.DataTime < startDate {
  499. continue
  500. }
  501. newDataList = append(newDataList, d)
  502. if firstFlag {
  503. maxData = d.Value
  504. minData = d.Value
  505. firstFlag = false
  506. } else {
  507. if d.Value > maxData {
  508. maxData = d.Value
  509. }
  510. if d.Value < minData {
  511. minData = d.Value
  512. }
  513. }
  514. }
  515. }
  516. edbInfoMappingList[k].DataList = newDataList
  517. edbInfoMappingList[k].MinData = minData
  518. edbInfoMappingList[k].MaxData = maxData
  519. }
  520. }
  521. dataResp = data_manage.ChartRangeAnalysisDataResp{ChartRangeAnalysisExtraConf: req}
  522. if req.MultipleGraphConfigId > 0 {
  523. multipleGraphConfigEdbMappingList, e := data_manage.GetMultipleGraphConfigEdbMappingListByIdAndSource(req.MultipleGraphConfigId, utils.CHART_SOURCE_RANGE_ANALYSIS)
  524. if e != nil && e.Error() != utils.ErrNoRow() {
  525. err = fmt.Errorf("获取区间计算图表, 指标信息失败, Err:" + e.Error())
  526. return
  527. }
  528. // 查询是否已经生成指标
  529. dataResp.ConfigEdbNum = len(multipleGraphConfigEdbMappingList)
  530. }
  531. edbList, err = GetChartEdbInfoFormat(chartInfoId, edbInfoMappingList)
  532. if err != nil {
  533. err = fmt.Errorf("获取区间计算图表, 完善指标信息失败, Err:" + err.Error())
  534. return
  535. }
  536. return
  537. }
  538. func GetChartDataByEdbInfoListBySeries(chartInfoId int, dateType, startYear int, startDate, endDate string, edbInfoMappingList []*data_manage.ChartEdbInfoMapping, req *data_manage.ChartRangeAnalysisExtraConf) (edbList []*data_manage.ChartEdbInfoMapping, xEdbIdValue []int, dataResp data_manage.ChartRangeAnalysisDataResp, err error) {
  539. //查询seriesId
  540. chartSeriesOb := new(data_manage.FactorEdbSeriesChartMapping)
  541. seriesMappingItem, err := chartSeriesOb.GetItemByChartInfoId(chartInfoId)
  542. if err != nil {
  543. if err.Error() == utils.ErrNoRow() {
  544. err = fmt.Errorf("图表关联关系不存在")
  545. return
  546. } else {
  547. err = fmt.Errorf("获取图表关联失败, Err: " + err.Error())
  548. return
  549. }
  550. }
  551. //根据seriesId查询数据
  552. //并把数据放到dataList中
  553. for _, edbInfoMapping := range edbInfoMappingList {
  554. dataOb := new(data_manage.FactorEdbSeriesCalculateDataQjjs)
  555. dataList, e := dataOb.GetEdbDataList(seriesMappingItem.FactorEdbSeriesId, edbInfoMapping.EdbInfoId, startDate, endDate)
  556. if e != nil {
  557. err = e
  558. return
  559. }
  560. if req.CalculateType == 2 || req.CalculateType == 3 {
  561. edbInfoMapping.Unit = "无"
  562. edbInfoMapping.UnitEn = "无"
  563. }
  564. edbInfoMapping.DataList = dataList
  565. // 处理上下限
  566. var maxData, minData float64
  567. if len(dataList) > 0 {
  568. maxData = dataList[0].Value
  569. minData = dataList[0].Value
  570. for _, v := range dataList {
  571. if v.Value > maxData {
  572. maxData = v.Value
  573. }
  574. if v.Value < minData {
  575. minData = v.Value
  576. }
  577. }
  578. }
  579. edbInfoMapping.MaxData = maxData
  580. edbInfoMapping.MinData = minData
  581. xEdbIdValue = append(xEdbIdValue, edbInfoMapping.EdbInfoId)
  582. }
  583. yearMax := 0
  584. if dateType == utils.DateTypeNYears {
  585. for _, v := range edbInfoMappingList {
  586. dataList := v.DataList.([]*data_manage.EdbDataList)
  587. latestDate := dataList[0].DataTime
  588. if latestDate != "" {
  589. lastDateT, tErr := time.Parse(utils.FormatDate, latestDate)
  590. if tErr != nil {
  591. err = fmt.Errorf("获取图表日期信息失败,Err:" + tErr.Error())
  592. return
  593. }
  594. if lastDateT.Year() > yearMax {
  595. yearMax = lastDateT.Year()
  596. }
  597. }
  598. }
  599. }
  600. startDate, endDate = utils.GetDateByDateTypeV2(dateType, startDate, endDate, startYear, yearMax)
  601. if startDate != "" {
  602. for k, v := range edbInfoMappingList {
  603. var maxData, minData float64
  604. dataList := v.DataList.([]*data_manage.EdbDataList)
  605. newDataList := make([]*data_manage.EdbDataList, 0)
  606. if len(dataList) == 0 {
  607. newDataList = dataList
  608. } else {
  609. firstFlag := true
  610. for _, d := range dataList {
  611. if endDate != "" && d.DataTime > endDate {
  612. continue
  613. }
  614. if d.DataTime < startDate {
  615. continue
  616. }
  617. newDataList = append(newDataList, d)
  618. if firstFlag {
  619. maxData = d.Value
  620. minData = d.Value
  621. firstFlag = false
  622. } else {
  623. if d.Value > maxData {
  624. maxData = d.Value
  625. }
  626. if d.Value < minData {
  627. minData = d.Value
  628. }
  629. }
  630. }
  631. }
  632. edbInfoMappingList[k].DataList = newDataList
  633. edbInfoMappingList[k].MinData = minData
  634. edbInfoMappingList[k].MaxData = maxData
  635. }
  636. }
  637. dataResp = data_manage.ChartRangeAnalysisDataResp{ChartRangeAnalysisExtraConf: req, SeriesId: seriesMappingItem.FactorEdbSeriesId}
  638. // 查询配置关联关系
  639. if req.MultipleGraphConfigId > 0 {
  640. multipleGraphConfigEdbMappingList, e := data_manage.GetMultipleGraphConfigEdbMappingListByIdAndSource(req.MultipleGraphConfigId, utils.CHART_SOURCE_RANGE_ANALYSIS)
  641. if e != nil && e.Error() != utils.ErrNoRow() {
  642. err = fmt.Errorf("获取区间计算图表, 指标信息失败, Err:" + e.Error())
  643. return
  644. }
  645. // 查询是否已经生成指标
  646. dataResp.ConfigEdbNum = len(multipleGraphConfigEdbMappingList)
  647. }
  648. edbList, err = GetChartEdbInfoFormat(chartInfoId, edbInfoMappingList)
  649. if err != nil {
  650. err = fmt.Errorf("获取区间计算图表, 完善指标信息失败, Err:" + err.Error())
  651. return
  652. }
  653. return
  654. }
  655. // getChartDataByEdbInfo 区间计算图表-根据指标信息获取x轴和y轴
  656. func getChartDataByEdbInfo(edbInfoMapping *data_manage.ChartEdbInfoMapping, req *data_manage.ChartRangeAnalysisExtraConf) (newEdbInfoMapping *data_manage.ChartEdbInfoMapping, err error) {
  657. newEdbInfoMapping = edbInfoMapping
  658. // 指标的开始日期和结束日期
  659. edbStartDateTime, _ := time.ParseInLocation(utils.FormatDate, edbInfoMapping.StartDate, time.Local)
  660. //edbStartDate := edbStartDateTime.AddDate(0, 0, 1).Format(utils.FormatDate)
  661. edbEndDateTime, _ := time.ParseInLocation(utils.FormatDate, edbInfoMapping.EndDate, time.Local)
  662. edbEndDate := edbEndDateTime.AddDate(0, 0, 1).Format(utils.FormatDate)
  663. // 获取时间基准指标在时间区间内的值
  664. dataListTmp := make([]*data_manage.EdbDataList, 0)
  665. switch edbInfoMapping.EdbInfoCategoryType {
  666. case 0:
  667. dataListTmp, err = data_manage.GetEdbDataList(edbInfoMapping.Source, edbInfoMapping.SubSource, edbInfoMapping.EdbInfoId, "", "")
  668. case 1:
  669. _, dataListTmp, _, _, err, _ = data.GetPredictDataListByPredictEdbInfoId(edbInfoMapping.EdbInfoId, "", "", false)
  670. default:
  671. err = errors.New("指标base类型异常")
  672. return
  673. }
  674. var dataList data_manage.SortEdbDataList
  675. dataList = dataListTmp
  676. sort.Sort(dataList)
  677. dateList := make([]*data_manage.ChartRangeAnalysisDateDataItem, 0)
  678. switch req.DateRangeType {
  679. case 0:
  680. // 智能划分得到一个开始日期,和结束日期
  681. var startDateTime, endDateTime time.Time
  682. startDateTime = edbStartDateTime
  683. /*if req.AutoDateConf.IsAutoStartDate == 0 { //固定设置
  684. startDate := req.AutoDateConf.StartDate
  685. if startDate == "" {
  686. startDate = "2020-01-01"
  687. }
  688. startDateTime, _ = time.ParseInLocation(utils.FormatDate, startDate, time.Local)
  689. } else {
  690. startConf := req.AutoDateConf.StartDateConf
  691. startDate := ""
  692. if startConf.BaseDateType == 0 { //
  693. startDate = edbEndDate
  694. } else if startConf.BaseDateType == 1 {
  695. startDate = time.Now().Format(utils.FormatDate)
  696. }
  697. if startConf.MoveForward > 0 {
  698. startDate = GetEdbDateByMoveForward(startConf.MoveForward, dataList)
  699. }
  700. if len(startConf.DateChange) > 0 {
  701. startDate, err = HandleEdbDateChange(startDate, startConf.DateChange)
  702. if err != nil {
  703. err = fmt.Errorf("智能划分开始日期处理失败:%s", err.Error())
  704. return
  705. }
  706. }
  707. startDateTime, _ = time.ParseInLocation(utils.FormatDate, startDate, time.Local)
  708. }*/
  709. if req.AutoDateConf.IsAutoEndDate == 0 { //固定设置
  710. endDate := req.AutoDateConf.EndDate
  711. if endDate == "" {
  712. err = fmt.Errorf("智能划分截止日期处理失败:请输入截止日期")
  713. return
  714. }
  715. // todo 如果截止日期比指标日期还要大,则用指标的最新日期
  716. endDateTime, _ = time.ParseInLocation(utils.FormatDate, endDate, time.Local)
  717. } else {
  718. endConf := req.AutoDateConf.EndDateConf
  719. endDate := edbEndDate
  720. if endConf.MoveForward > 0 {
  721. endDate = GetEdbDateByMoveForward(endDate, endConf.MoveForward, dataList)
  722. }
  723. if len(endConf.DateChange) > 0 {
  724. endDate, err = HandleEdbDateChange(endDate, endConf.DateChange)
  725. if err != nil {
  726. err = fmt.Errorf("智能划分结束日期处理失败:%s", err.Error())
  727. return
  728. }
  729. }
  730. endDateTime, _ = time.ParseInLocation(utils.FormatDate, endDate, time.Local)
  731. }
  732. dateList = append(dateList, &data_manage.ChartRangeAnalysisDateDataItem{
  733. StartDate: startDateTime,
  734. EndDate: endDateTime})
  735. case 1:
  736. // 手工划分得到多个开始日期和结束日期(已排序)
  737. for _, v := range req.ManualDateConf {
  738. startDateT, _ := time.ParseInLocation(utils.FormatDate, v.StartDate, time.Local)
  739. endDateT, _ := time.ParseInLocation(utils.FormatDate, v.EndDate, time.Local)
  740. tmp := &data_manage.ChartRangeAnalysisDateDataItem{
  741. StartDate: startDateT,
  742. EndDate: endDateT,
  743. }
  744. dateList = append(dateList, tmp)
  745. }
  746. case 2:
  747. // 跨年划分得到多个开始日期和结束日期
  748. startYear := edbStartDateTime.Year()
  749. endYear := edbEndDateTime.Year()
  750. startDay := req.YearDateConf.StartDay
  751. endDay := req.YearDateConf.EndDay
  752. for year := startYear; year <= endYear; year++ {
  753. startDate := fmt.Sprintf("%d-%s", year, startDay)
  754. endDate := fmt.Sprintf("%d-%s", year+1, endDay)
  755. startDateTime, _ := time.ParseInLocation(utils.FormatDate, startDate, time.Local)
  756. endDateTime, _ := time.ParseInLocation(utils.FormatDate, endDate, time.Local)
  757. if startDateTime.Before(edbStartDateTime) {
  758. break
  759. }
  760. tmp := &data_manage.ChartRangeAnalysisDateDataItem{
  761. StartDate: startDateTime,
  762. EndDate: endDateTime,
  763. }
  764. dateList = append(dateList, tmp)
  765. }
  766. }
  767. // 根据日期,获取数据
  768. for _, v := range dateList {
  769. for _, vv := range dataList {
  770. dataTimeT, _ := time.ParseInLocation(utils.FormatDate, vv.DataTime, time.Local)
  771. if dataTimeT.After(v.StartDate) && dataTimeT.Before(v.EndDate) ||
  772. dataTimeT.Equal(v.StartDate) ||
  773. dataTimeT.Equal(v.EndDate) {
  774. v.DataList = append(v.DataList, vv)
  775. }
  776. }
  777. }
  778. // 根据时间区间类型来获取数据的计算窗口,然后再拼接成整段数据
  779. newDataList, err := HandleDataByCalculateType(dateList, dataList, req)
  780. if err != nil {
  781. return
  782. }
  783. if req.UnNormalDataDealType > 0 {
  784. switch req.UnNormalDataDealType { //0:不处理,1:剔除,2替换
  785. case 1:
  786. dealDataList := make([]*data_manage.EdbDataList, 0)
  787. for _, v := range newDataList {
  788. if !utils.CompareFloatByOpStrings(req.UnNormalDataConf.Formula, v.Value, req.UnNormalDataConf.Value) {
  789. dealDataList = append(dealDataList, v)
  790. }
  791. }
  792. case 2:
  793. for i, v := range newDataList {
  794. if utils.CompareFloatByOpStrings(req.UnNormalDataConf.Formula, v.Value, req.UnNormalDataConf.Value) {
  795. newDataList[i].Value = req.UnNormalDataConf.ReplaceValue
  796. }
  797. }
  798. }
  799. }
  800. if req.DataConvertType > 0 {
  801. // 数据转换类型 0不转, 1乘 2除 3对数
  802. switch req.DataConvertType {
  803. case 1:
  804. for i, v := range newDataList {
  805. val := v.Value * req.DataConvertConf.Value
  806. val, _ = decimal.NewFromFloat(val).Round(4).Float64()
  807. newDataList[i].Value = val
  808. }
  809. //item.MaxData = item.MaxData * v.ConvertValue
  810. //item.MinData = item.MinData * v.ConvertValue
  811. case 2:
  812. for i, v := range newDataList {
  813. val := v.Value / req.DataConvertConf.Value
  814. val, _ = decimal.NewFromFloat(val).Round(4).Float64()
  815. newDataList[i].Value = val
  816. }
  817. //item.MaxData = item.MaxData / v.ConvertValue
  818. //item.MinData = item.MinData / v.ConvertValue
  819. case 3:
  820. for i, v := range newDataList {
  821. if v.Value <= 0 {
  822. err = errors.New("数据中含有负数或0,无法对数运算")
  823. return
  824. }
  825. val := math.Log(v.Value) / math.Log(req.DataConvertConf.Value)
  826. val, _ = decimal.NewFromFloat(val).Round(4).Float64()
  827. newDataList[i].Value = val
  828. }
  829. //item.MaxData = math.Log(item.MaxData) / math.Log(v.ConvertValue)
  830. //item.MinData = math.Log(item.MinData) / math.Log(v.ConvertValue)
  831. }
  832. }
  833. newEdbInfoMapping.DataList = newDataList
  834. //时间处理
  835. return
  836. }
  837. // RollingCorrelationChartDataResp 滚动区间计算图表数据
  838. type RollingCorrelationChartDataResp struct {
  839. MaxData float64
  840. MinData float64
  841. LatestDate string `description:"真实数据的最后日期"`
  842. EdbInfoCategoryType int
  843. ChartColor string
  844. ChartStyle string
  845. PredictChartColor string
  846. ChartType int
  847. ChartWidth int
  848. EdbName string
  849. EdbNameEn string
  850. Unit string
  851. UnitEn string
  852. IsAxis int
  853. DataList []data_manage.EdbDataList
  854. }
  855. // ChartInfoRefresh 图表刷新
  856. func ChartInfoRefresh(chartInfoId int, uniqueCode string) (isAsync bool, err error) {
  857. var errMsg string
  858. defer func() {
  859. if err != nil {
  860. tips := fmt.Sprintf("CorrelationChartInfoRefresh: %s", errMsg)
  861. utils.FileLog.Info(tips)
  862. go alarm_msg.SendAlarmMsg(tips, 3)
  863. }
  864. }()
  865. var chartInfo *data_manage.ChartInfo
  866. if chartInfoId > 0 {
  867. chartInfo, err = data_manage.GetChartInfoById(chartInfoId)
  868. if err != nil {
  869. if err.Error() == utils.ErrNoRow() {
  870. errMsg = "图表已被删除,请刷新页面"
  871. err = errors.New(errMsg)
  872. return
  873. }
  874. errMsg = "获取图表信息失败"
  875. err = errors.New("获取图表信息失败,Err:" + err.Error())
  876. return
  877. }
  878. } else {
  879. chartInfo, err = data_manage.GetChartInfoByUniqueCode(uniqueCode)
  880. if err != nil {
  881. if err.Error() == utils.ErrNoRow() {
  882. errMsg = "图表已被删除,请刷新页面"
  883. err = errors.New(errMsg)
  884. return
  885. }
  886. errMsg = "获取图表信息失败"
  887. err = errors.New("获取图表信息失败,Err:" + err.Error())
  888. return
  889. }
  890. }
  891. // 1.刷新图表关联的指标
  892. mappings, e := data_manage.GetChartEdbMappingList(chartInfoId)
  893. if e != nil {
  894. utils.FileLog.Info(fmt.Sprintf("获取图表关联指标失败, err: %v", e))
  895. return
  896. }
  897. if len(mappings) == 0 {
  898. utils.FileLog.Info("图表无关联指标")
  899. return
  900. }
  901. var edbIds []int
  902. for _, v := range mappings {
  903. edbIds = append(edbIds, v.EdbInfoId)
  904. }
  905. if e, _ = data.EdbInfoRefreshAllFromBaseV3(edbIds, false, true, false); e != nil {
  906. utils.FileLog.Info(fmt.Sprintf("批量刷新指标失败, err: %v", e))
  907. return
  908. }
  909. // todo 重新计算
  910. // 区间计算图表配置校验
  911. var extraConfig data_manage.ChartRangeAnalysisExtraConf
  912. err = json.Unmarshal([]byte(chartInfo.ExtraConfig), &extraConfig)
  913. if err != nil {
  914. errMsg = "配置信息错误"
  915. err = errors.New(errMsg + ", Err: " + err.Error())
  916. return
  917. }
  918. chartSeriesOb := new(data_manage.FactorEdbSeriesChartMapping)
  919. seriesMappingItem, err := chartSeriesOb.GetItemByChartInfoId(chartInfo.ChartInfoId)
  920. if err != nil {
  921. if err.Error() == utils.ErrNoRow() {
  922. err = nil
  923. } else {
  924. err = fmt.Errorf("获取图表关联失败, Err: " + err.Error())
  925. return
  926. }
  927. } else {
  928. _, e = FactorEdbStepCalculateRange(seriesMappingItem.FactorEdbSeriesId, edbIds, extraConfig, true)
  929. if e != nil {
  930. err = fmt.Errorf("计算因子指标失败, Err: " + e.Error())
  931. return
  932. }
  933. }
  934. // 4.清除图表缓存
  935. key := utils.HZ_CHART_LIB_DETAIL + uniqueCode
  936. _ = utils.Rc.Delete(key)
  937. return
  938. }
  939. // AddChartInfo 添加图表
  940. func AddChartInfo(req data_manage.AddChartInfoReq, source int, sysUser *system.Admin, lang string) (chartInfo *data_manage.ChartInfo, err error, errMsg string, isSendEmail bool) {
  941. isSendEmail = true
  942. req.ChartName = strings.Trim(req.ChartName, " ")
  943. if req.ChartName == "" {
  944. errMsg = "请填写图表名称!"
  945. err = errors.New(errMsg)
  946. isSendEmail = false
  947. return
  948. }
  949. if req.ChartClassifyId <= 0 {
  950. errMsg = "分类参数错误!"
  951. err = errors.New(errMsg)
  952. isSendEmail = false
  953. return
  954. }
  955. // 区间计算图表配置校验
  956. var extraConfig data_manage.ChartRangeAnalysisExtraConf
  957. if req.ExtraConfig == `` {
  958. errMsg = "配置信息错误"
  959. err = errors.New(errMsg)
  960. return
  961. }
  962. err = json.Unmarshal([]byte(req.ExtraConfig), &extraConfig)
  963. if err != nil {
  964. errMsg = "配置信息错误"
  965. err = errors.New(errMsg + ", Err: " + err.Error())
  966. return
  967. }
  968. if len(req.ChartEdbInfoList) <= 0 {
  969. errMsg = "请选择指标"
  970. err = errors.New(errMsg)
  971. isSendEmail = false
  972. return
  973. }
  974. if len(req.ChartEdbInfoList) > 100 {
  975. errMsg = "添加指标总数量不得超过100"
  976. err = errors.New(errMsg)
  977. isSendEmail = false
  978. return
  979. }
  980. err, errMsg, isSendEmail = CheckChartRangeExtraConfig(extraConfig)
  981. if err != nil {
  982. return
  983. }
  984. chartClassify, err := data_manage.GetChartClassifyById(req.ChartClassifyId)
  985. if err != nil {
  986. if err.Error() == utils.ErrNoRow() {
  987. errMsg = "分类不存在"
  988. err = errors.New(errMsg)
  989. isSendEmail = false
  990. return
  991. }
  992. errMsg = "获取分类信息失败"
  993. err = errors.New("获取分类信息失败,Err:" + err.Error())
  994. return
  995. }
  996. if chartClassify == nil {
  997. errMsg = "分类不存在"
  998. err = errors.New(errMsg)
  999. isSendEmail = false
  1000. return
  1001. }
  1002. var edbInfoIdArr []int
  1003. for _, v := range req.ChartEdbInfoList {
  1004. edbInfoId := v.EdbInfoId
  1005. edbInfo, tmpErr := data_manage.GetEdbInfoById(edbInfoId)
  1006. if tmpErr != nil {
  1007. if tmpErr.Error() == utils.ErrNoRow() {
  1008. errMsg = "指标不存在!"
  1009. err = errors.New("指标不存在,edbInfoId:" + strconv.Itoa(edbInfoId))
  1010. return
  1011. } else {
  1012. errMsg = "获取指标信息失败!"
  1013. err = errors.New("获取图表的指标信息失败,Err:" + tmpErr.Error())
  1014. return
  1015. }
  1016. }
  1017. if edbInfo == nil {
  1018. errMsg = "指标已被删除,请重新选择!"
  1019. err = errors.New("指标不存在,ChartInfoId:" + strconv.Itoa(edbInfoId))
  1020. return
  1021. } else {
  1022. if edbInfo.EdbInfoId <= 0 {
  1023. errMsg = "指标已被删除,请重新选择!"
  1024. err = errors.New("指标不存在,ChartInfoId:" + strconv.Itoa(edbInfoId))
  1025. return
  1026. }
  1027. }
  1028. edbInfoIdArr = append(edbInfoIdArr, edbInfoId)
  1029. edbInfo.EdbNameSource = edbInfo.EdbName
  1030. }
  1031. sort.Ints(edbInfoIdArr)
  1032. var edbInfoIdArrStr []string
  1033. for _, v := range edbInfoIdArr {
  1034. edbInfoIdArrStr = append(edbInfoIdArrStr, strconv.Itoa(v))
  1035. }
  1036. edbInfoIdStr := strings.Join(edbInfoIdArrStr, ",")
  1037. var chartInfoId int
  1038. // 判断图表是否存在
  1039. {
  1040. var condition string
  1041. var pars []interface{}
  1042. switch lang {
  1043. case utils.EnLangVersion:
  1044. condition += " AND chart_name_en = ? AND source = ? "
  1045. default:
  1046. condition += " AND chart_name=? AND source = ? "
  1047. }
  1048. pars = append(pars, req.ChartName, source)
  1049. count, tmpErr := data_manage.GetChartInfoCountByCondition(condition, pars)
  1050. if tmpErr != nil {
  1051. errMsg = "判断图表名称是否存在失败"
  1052. err = errors.New("判断图表名称是否存在失败,Err:" + tmpErr.Error())
  1053. return
  1054. }
  1055. if count > 0 {
  1056. errMsg = "图表已存在,请重新填写"
  1057. err = errors.New(errMsg)
  1058. isSendEmail = false
  1059. return
  1060. }
  1061. }
  1062. disableVal := data.CheckIsDisableChart(edbInfoIdArr)
  1063. chartInfo = new(data_manage.ChartInfo)
  1064. chartInfo.ChartName = req.ChartName
  1065. chartInfo.ChartNameEn = req.ChartName
  1066. chartInfo.EdbInfoIds = edbInfoIdStr
  1067. chartInfo.ChartClassifyId = req.ChartClassifyId
  1068. chartInfo.SysUserId = sysUser.AdminId
  1069. chartInfo.SysUserRealName = sysUser.RealName
  1070. chartInfo.CreateTime = time.Now()
  1071. chartInfo.ModifyTime = time.Now()
  1072. chartInfo.IsSetName = 0
  1073. timestamp := strconv.FormatInt(time.Now().UnixNano(), 10)
  1074. chartInfo.UniqueCode = utils.MD5(utils.CHART_PREFIX + "_" + timestamp)
  1075. chartInfo.ChartType = 1 // 区间计算图
  1076. chartInfo.Calendar = "公历"
  1077. chartInfo.DateType = 6
  1078. chartInfo.StartDate = req.StartDate
  1079. chartInfo.EndDate = req.EndDate
  1080. chartInfo.SeasonStartDate = req.StartDate
  1081. chartInfo.SeasonEndDate = req.EndDate
  1082. chartInfo.LeftMin = req.LeftMin
  1083. chartInfo.LeftMax = req.LeftMax
  1084. chartInfo.RightMin = req.RightMin
  1085. chartInfo.RightMax = req.RightMax
  1086. chartInfo.Disabled = disableVal
  1087. chartInfo.Source = source
  1088. chartInfo.ChartThemeId = req.ChartThemeId
  1089. chartInfo.SourcesFrom = req.SourcesFrom
  1090. chartInfo.Instructions = req.Instructions
  1091. chartInfo.MarkersLines = req.MarkersLines
  1092. chartInfo.MarkersAreas = req.MarkersAreas
  1093. if req.ExtraConfig != "" {
  1094. chartInfo.ExtraConfig = req.ExtraConfig
  1095. }
  1096. // 指标信息
  1097. mapList := make([]*data_manage.ChartEdbMapping, 0)
  1098. for _, v := range req.ChartEdbInfoList {
  1099. // todo 指标名称修改
  1100. mapItem := new(data_manage.ChartEdbMapping)
  1101. mapItem.EdbInfoId = v.EdbInfoId
  1102. mapItem.EdbAliasName = v.EdbAliasName
  1103. mapItem.IsAxis = v.IsAxis
  1104. mapItem.CreateTime = time.Now()
  1105. mapItem.ModifyTime = time.Now()
  1106. edbTimestamp := strconv.FormatInt(time.Now().UnixNano(), 10)
  1107. mapItem.UniqueCode = utils.MD5(utils.CHART_PREFIX + "_" + edbTimestamp + "_" + strconv.Itoa(v.EdbInfoId))
  1108. mapItem.IsOrder = false
  1109. mapItem.EdbInfoType = 1
  1110. mapItem.Source = utils.CHART_SOURCE_RANGE_ANALYSIS
  1111. mapList = append(mapList, mapItem)
  1112. }
  1113. // 新增图表和指标mapping
  1114. chartInfoId, e := data_manage.CreateRangeChartAndEdb(chartInfo, mapList)
  1115. if e != nil {
  1116. errMsg = "操作失败"
  1117. err = errors.New("新增区间计算图表失败, Err: " + e.Error())
  1118. return
  1119. }
  1120. // 把系列和图表绑定
  1121. if extraConfig.EdbInfoMode == 1 {
  1122. // 新增指标系列
  1123. err = AddSeries(edbInfoIdArr, chartInfoId, utils.CHART_SOURCE_RANGE_ANALYSIS, extraConfig, req.ExtraConfig)
  1124. if err != nil {
  1125. errMsg = "操作失败"
  1126. err = errors.New("新增区间计算图表失败, Err: " + err.Error())
  1127. return
  1128. }
  1129. //todo 如果保存失败是否要删除
  1130. }
  1131. /*//添加配置信息
  1132. multipleGraphConfig := &data_manage.MultipleGraphConfig{
  1133. //MultipleGraphConfigId: 0,
  1134. SysUserId: sysUser.AdminId,
  1135. SysUserRealName: sysUser.RealName,
  1136. ModifyTime: time.Now(),
  1137. CreateTime: time.Now(),
  1138. }
  1139. err = data_manage.AddMultipleGraphConfig(multipleGraphConfig)
  1140. if err != nil {
  1141. errMsg = "操作失败"
  1142. err = errors.New("新增区间计算图表配置失败, Err: " + err.Error())
  1143. return
  1144. }*/
  1145. if extraConfig.MultipleGraphConfigId > 0 {
  1146. multipleGraphConfigChartMapping := &data_manage.MultipleGraphConfigChartMapping{
  1147. //Id: 0,
  1148. MultipleGraphConfigId: extraConfig.MultipleGraphConfigId,
  1149. ChartInfoId: chartInfo.ChartInfoId,
  1150. Source: utils.CHART_SOURCE_RANGE_ANALYSIS,
  1151. ModifyTime: time.Now(),
  1152. CreateTime: time.Now(),
  1153. }
  1154. err = data_manage.AddMultipleGraphConfigChartMapping(multipleGraphConfigChartMapping)
  1155. if err != nil {
  1156. errMsg = "操作失败"
  1157. err = errors.New("新增区间计算图表和配置关联关系失败, Err: " + err.Error())
  1158. return
  1159. }
  1160. }
  1161. // 添加指标引用记录
  1162. _ = data.SaveChartEdbInfoRelation(edbInfoIdArr, chartInfo)
  1163. //添加es数据
  1164. go data.EsAddOrEditChartInfo(chartInfoId)
  1165. return
  1166. }
  1167. // EditChartInfo 编辑图表
  1168. func EditChartInfo(req data_manage.EditChartInfoReq, sysUser *system.Admin, lang string) (chartItem *data_manage.ChartInfo, err error, errMsg string, isSendEmail bool) {
  1169. isSendEmail = true
  1170. chartItem, err = data_manage.GetChartInfoById(req.ChartInfoId)
  1171. if err != nil {
  1172. if err.Error() == utils.ErrNoRow() {
  1173. errMsg = "图表已被删除,请刷新页面"
  1174. err = errors.New(errMsg)
  1175. isSendEmail = false
  1176. return
  1177. }
  1178. errMsg = "获取图表信息失败"
  1179. err = errors.New("获取图表信息失败,Err:" + err.Error())
  1180. return
  1181. }
  1182. if chartItem.Source != utils.CHART_SOURCE_RANGE_ANALYSIS {
  1183. errMsg = "该图不是区间计算图表!"
  1184. err = errors.New(errMsg)
  1185. isSendEmail = false
  1186. return
  1187. }
  1188. req.ChartName = strings.Trim(req.ChartName, " ")
  1189. if req.ChartClassifyId <= 0 {
  1190. errMsg = "分类参数错误!"
  1191. err = errors.New(errMsg)
  1192. isSendEmail = false
  1193. return
  1194. }
  1195. // 区间计算图表配置校验
  1196. var extraConfig data_manage.ChartRangeAnalysisExtraConf
  1197. if req.ExtraConfig == `` {
  1198. errMsg = "配置信息错误"
  1199. err = errors.New(errMsg)
  1200. return
  1201. }
  1202. err = json.Unmarshal([]byte(req.ExtraConfig), &extraConfig)
  1203. if err != nil {
  1204. errMsg = "配置信息错误"
  1205. err = errors.New(errMsg)
  1206. return
  1207. }
  1208. if len(req.ChartEdbInfoList) <= 0 {
  1209. errMsg = "请选择指标"
  1210. err = errors.New(errMsg)
  1211. isSendEmail = false
  1212. return
  1213. }
  1214. extraConfig.SeriesName = strings.TrimSpace(extraConfig.SeriesName)
  1215. if len(req.ChartEdbInfoList) > 100 {
  1216. errMsg = "添加指标总数量不得超过100"
  1217. err = errors.New(errMsg)
  1218. isSendEmail = false
  1219. return
  1220. }
  1221. err, errMsg, isSendEmail = CheckChartRangeExtraConfig(extraConfig)
  1222. if err != nil {
  1223. return
  1224. }
  1225. chartClassify, err := data_manage.GetChartClassifyById(req.ChartClassifyId)
  1226. if err != nil {
  1227. if err.Error() == utils.ErrNoRow() {
  1228. errMsg = "分类不存在"
  1229. err = errors.New(errMsg)
  1230. isSendEmail = false
  1231. return
  1232. }
  1233. errMsg = "获取分类信息失败"
  1234. err = errors.New("获取分类信息失败,Err:" + err.Error())
  1235. return
  1236. }
  1237. if chartClassify == nil {
  1238. errMsg = "分类不存在"
  1239. err = errors.New(errMsg)
  1240. isSendEmail = false
  1241. return
  1242. }
  1243. // 图表操作权限
  1244. ok := data.CheckOpChartPermission(sysUser, chartItem.SysUserId, true)
  1245. if !ok {
  1246. errMsg = "没有该图表的操作权限"
  1247. err = errors.New(errMsg)
  1248. isSendEmail = false
  1249. return
  1250. }
  1251. var edbInfoIdArr []int
  1252. for _, v := range req.ChartEdbInfoList {
  1253. edbInfoId := v.EdbInfoId
  1254. edbInfo, tmpErr := data_manage.GetEdbInfoById(edbInfoId)
  1255. if tmpErr != nil {
  1256. if tmpErr.Error() == utils.ErrNoRow() {
  1257. errMsg = "图表不存在!"
  1258. err = errors.New("图表指标不存在,ChartInfoId:" + strconv.Itoa(edbInfoId))
  1259. return
  1260. } else {
  1261. errMsg = "获取图表信息失败!"
  1262. err = errors.New("获取图表的指标信息失败,Err:" + tmpErr.Error())
  1263. return
  1264. }
  1265. }
  1266. if edbInfo == nil {
  1267. errMsg = "指标不存在!"
  1268. err = errors.New("指标不存在,ChartInfoId:" + strconv.Itoa(edbInfoId))
  1269. return
  1270. }
  1271. edbInfoIdArr = append(edbInfoIdArr, edbInfoId)
  1272. }
  1273. sort.Ints(edbInfoIdArr)
  1274. var edbInfoIdArrStr []string
  1275. for _, v := range edbInfoIdArr {
  1276. edbInfoIdArrStr = append(edbInfoIdArrStr, strconv.Itoa(v))
  1277. }
  1278. edbInfoIdStr := strings.Join(edbInfoIdArrStr, ",")
  1279. //判断图表是否存在
  1280. {
  1281. var condition string
  1282. var pars []interface{}
  1283. condition += " AND chart_info_id <> ? "
  1284. pars = append(pars, req.ChartInfoId)
  1285. switch lang {
  1286. case utils.EnLangVersion:
  1287. condition += " AND chart_name_en = ? AND source = ? "
  1288. default:
  1289. condition += " AND chart_name=? AND source = ? "
  1290. }
  1291. pars = append(pars, req.ChartName, chartItem.Source)
  1292. count, tmpErr := data_manage.GetChartInfoCountByCondition(condition, pars)
  1293. if tmpErr != nil {
  1294. errMsg = "判断图表名称是否存在失败"
  1295. err = errors.New("判断图表名称是否存在失败,Err:" + tmpErr.Error())
  1296. return
  1297. }
  1298. if count > 0 {
  1299. errMsg = "图表已存在,请重新填写"
  1300. err = errors.New(errMsg)
  1301. isSendEmail = false
  1302. return
  1303. }
  1304. }
  1305. // 修改图表与指标mapping
  1306. req.ChartType = 1
  1307. dateType := req.DateType
  1308. err = data_manage.EditRangeChartInfoAndMapping(&req, edbInfoIdStr, lang, "公历", dateType, 0, ``)
  1309. if err != nil {
  1310. errMsg = "保存失败"
  1311. err = errors.New("保存失败,Err:" + err.Error())
  1312. return
  1313. }
  1314. addSeries := false
  1315. chartSeriesOb := new(data_manage.FactorEdbSeriesChartMapping)
  1316. seriesMappingItem, err := chartSeriesOb.GetItemByChartInfoId(chartItem.ChartInfoId)
  1317. if err != nil {
  1318. if err.Error() == utils.ErrNoRow() {
  1319. err = nil
  1320. addSeries = true
  1321. } else {
  1322. err = fmt.Errorf("获取图表关联失败, Err: " + err.Error())
  1323. return
  1324. }
  1325. }
  1326. if extraConfig.EdbInfoMode == 1 {
  1327. if addSeries {
  1328. // 新增指标系列
  1329. err = AddSeries(edbInfoIdArr, chartItem.ChartInfoId, utils.CHART_SOURCE_RANGE_ANALYSIS, extraConfig, req.ExtraConfig)
  1330. if err != nil {
  1331. errMsg = "操作失败"
  1332. err = errors.New("新增区间计算图表失败, Err: " + err.Error())
  1333. return
  1334. }
  1335. } else {
  1336. err = EditSeries(seriesMappingItem, edbInfoIdArr, extraConfig, req.ExtraConfig, true)
  1337. if err != nil {
  1338. errMsg = "保存失败"
  1339. err = errors.New("保存失败,Err:" + err.Error())
  1340. return
  1341. }
  1342. }
  1343. // todo 编辑失败处理
  1344. } else if extraConfig.EdbInfoMode == 0 {
  1345. if !addSeries {
  1346. // 删除相关的系列
  1347. factorSeriesOb := new(data_manage.FactorEdbSeries)
  1348. err = factorSeriesOb.RemoveSeriesAndMappingByFactorEdbSeriesId(seriesMappingItem)
  1349. if err != nil {
  1350. errMsg = "保存失败"
  1351. err = errors.New("保存失败,Err:" + err.Error())
  1352. return
  1353. }
  1354. }
  1355. }
  1356. resp := new(data_manage.AddChartInfoResp)
  1357. resp.ChartInfoId = chartItem.ChartInfoId
  1358. resp.UniqueCode = chartItem.UniqueCode
  1359. resp.ChartType = req.ChartType
  1360. // 添加指标引用记录
  1361. _ = data.SaveChartEdbInfoRelation(edbInfoIdArr, chartItem)
  1362. //添加es数据
  1363. go data.EsAddOrEditChartInfo(chartItem.ChartInfoId)
  1364. //修改my eta es数据
  1365. go data.EsAddOrEditMyChartInfoByChartInfoId(chartItem.ChartInfoId)
  1366. return
  1367. }
  1368. // CopyChartInfo 复制图表
  1369. func CopyChartInfo(classifyId int, chartName string, oldChartInfo *data_manage.ChartInfo, sysUser *system.Admin, lang string) (chartInfo *data_manage.ChartInfo, err error, errMsg string, isSendEmail bool) {
  1370. isSendEmail = true
  1371. timestamp := strconv.FormatInt(time.Now().UnixNano(), 10)
  1372. chartInfo = &data_manage.ChartInfo{
  1373. ChartInfoId: 0,
  1374. ChartName: chartName,
  1375. ChartClassifyId: classifyId,
  1376. SysUserId: sysUser.AdminId,
  1377. SysUserRealName: sysUser.RealName,
  1378. UniqueCode: utils.MD5(utils.CHART_PREFIX + "_" + timestamp),
  1379. CreateTime: time.Now(),
  1380. ModifyTime: time.Now(),
  1381. DateType: oldChartInfo.DateType,
  1382. StartDate: oldChartInfo.StartDate,
  1383. EndDate: oldChartInfo.EndDate,
  1384. IsSetName: oldChartInfo.IsSetName,
  1385. EdbInfoIds: oldChartInfo.EdbInfoIds,
  1386. ChartType: oldChartInfo.ChartType,
  1387. Calendar: oldChartInfo.Calendar,
  1388. SeasonStartDate: oldChartInfo.SeasonStartDate,
  1389. SeasonEndDate: oldChartInfo.SeasonEndDate,
  1390. ChartImage: oldChartInfo.ChartImage,
  1391. BarConfig: oldChartInfo.BarConfig,
  1392. //Sort: sort,
  1393. LeftMin: oldChartInfo.LeftMin,
  1394. LeftMax: oldChartInfo.LeftMax,
  1395. RightMin: oldChartInfo.RightMin,
  1396. RightMax: oldChartInfo.RightMax,
  1397. Right2Min: oldChartInfo.Right2Min,
  1398. Right2Max: oldChartInfo.Right2Max,
  1399. Disabled: oldChartInfo.Disabled,
  1400. Source: oldChartInfo.Source,
  1401. ExtraConfig: oldChartInfo.ExtraConfig,
  1402. SeasonExtraConfig: oldChartInfo.SeasonExtraConfig,
  1403. StartYear: oldChartInfo.StartYear,
  1404. Unit: oldChartInfo.Unit,
  1405. UnitEn: oldChartInfo.UnitEn,
  1406. ChartThemeId: oldChartInfo.ChartThemeId,
  1407. SourcesFrom: oldChartInfo.SourcesFrom,
  1408. Instructions: oldChartInfo.Instructions,
  1409. MarkersLines: oldChartInfo.MarkersLines,
  1410. MarkersAreas: oldChartInfo.MarkersAreas,
  1411. }
  1412. newId, err := data_manage.AddChartInfo(chartInfo)
  1413. if err != nil {
  1414. err = fmt.Errorf("保存失败,Err:%s", err.Error())
  1415. return
  1416. }
  1417. chartInfo.ChartInfoId = int(newId)
  1418. edbInfoMappingList, err := data_manage.GetChartEdbMappingList(oldChartInfo.ChartInfoId)
  1419. if err != nil {
  1420. err = fmt.Errorf("获取图表,指标信息失败,Err:" + err.Error())
  1421. return
  1422. }
  1423. // 添加图表与指标的关联关系
  1424. edbInfoIdArr := make([]int, 0)
  1425. {
  1426. mapList := make([]*data_manage.ChartEdbMapping, 0)
  1427. for _, v := range edbInfoMappingList {
  1428. edbInfoIdArr = append(edbInfoIdArr, v.EdbInfoId)
  1429. timestamp = strconv.FormatInt(time.Now().UnixNano(), 10)
  1430. mapItem := &data_manage.ChartEdbMapping{
  1431. //ChartEdbMappingId: 0,
  1432. ChartInfoId: chartInfo.ChartInfoId,
  1433. EdbInfoId: v.EdbInfoId,
  1434. CreateTime: time.Now(),
  1435. ModifyTime: time.Now(),
  1436. UniqueCode: utils.MD5(utils.CHART_PREFIX + "_" + timestamp),
  1437. MaxData: v.MaxData,
  1438. MinData: v.MinData,
  1439. IsOrder: v.IsOrder,
  1440. IsAxis: v.IsAxis,
  1441. EdbInfoType: v.EdbInfoType,
  1442. LeadValue: v.LeadValue,
  1443. LeadUnit: v.LeadUnit,
  1444. ChartStyle: v.ChartStyle,
  1445. ChartColor: v.ChartColor,
  1446. ChartWidth: v.ChartWidth,
  1447. Source: v.Source,
  1448. EdbAliasName: v.EdbAliasName,
  1449. IsConvert: v.IsConvert,
  1450. ConvertType: v.ConvertType,
  1451. ConvertValue: v.ConvertValue,
  1452. ConvertUnit: v.ConvertEnUnit,
  1453. ConvertEnUnit: v.ConvertEnUnit,
  1454. }
  1455. mapList = append(mapList, mapItem)
  1456. }
  1457. err = data_manage.AddChartEdbMapping(mapList)
  1458. if err != nil {
  1459. err = fmt.Errorf("保存失败,Err:%s", err.Error())
  1460. return
  1461. }
  1462. }
  1463. // 添加系列和图表映射
  1464. chartSeriesOb := new(data_manage.FactorEdbSeriesChartMapping)
  1465. _, err = chartSeriesOb.GetItemByChartInfoId(oldChartInfo.ChartInfoId)
  1466. if err != nil {
  1467. if err.Error() == utils.ErrNoRow() {
  1468. err = nil
  1469. } else {
  1470. err = fmt.Errorf("获取图表关联失败, Err: " + err.Error())
  1471. return
  1472. }
  1473. } else {
  1474. // 新增指标系列
  1475. // 区间计算图表配置校验
  1476. var extraConfig data_manage.ChartRangeAnalysisExtraConf
  1477. err = json.Unmarshal([]byte(chartInfo.ExtraConfig), &extraConfig)
  1478. if err != nil {
  1479. errMsg = "配置信息错误"
  1480. err = errors.New(errMsg + ", Err: " + err.Error())
  1481. return
  1482. }
  1483. err = AddSeries(edbInfoIdArr, chartInfo.ChartInfoId, utils.CHART_SOURCE_RANGE_ANALYSIS, extraConfig, chartInfo.ExtraConfig)
  1484. if err != nil {
  1485. errMsg = "操作失败"
  1486. err = errors.New("新增区间计算图表失败, Err: " + err.Error())
  1487. return
  1488. }
  1489. }
  1490. //添加es数据
  1491. go data.EsAddOrEditChartInfo(chartInfo.ChartInfoId)
  1492. return
  1493. }
  1494. /*
  1495. // CalculateCorrelation 计算区间计算-获取x轴和y轴
  1496. func CalculateCorrelation(leadValue int, leadUnit, frequencyA, frequencyB string, dataListA, dataListB []*data_manage.EdbDataList) (xEdbIdValue []int, yDataList []data_manage.YData, err error) {
  1497. xData := make([]int, 0)
  1498. yData := make([]float64, 0)
  1499. if leadValue == 0 {
  1500. xData = append(xData, 0)
  1501. }
  1502. if leadValue > 0 {
  1503. leadMin := 0 - leadValue
  1504. xLen := 2*leadValue + 1
  1505. for i := 0; i < xLen; i++ {
  1506. n := leadMin + i
  1507. xData = append(xData, n)
  1508. }
  1509. }
  1510. // 计算窗口,不包含第一天
  1511. //startDateTime, _ := time.ParseInLocation(utils.FormatDate, startDate, time.Local)
  1512. //startDate = startDateTime.AddDate(0, 0, 1).Format(utils.FormatDate)
  1513. //// 2023-03-02 时间序列始终以指标B为基准, 始终是A进行平移
  1514. //baseEdbInfo := edbInfoMappingB
  1515. //changeEdbInfo := edbInfoMappingA
  1516. // 2023-03-17 时间序列始终以指标A为基准, 始终是B进行平移
  1517. //baseEdbInfo := edbInfoMappingA
  1518. //changeEdbInfo := edbInfoMappingB
  1519. // 获取时间基准指标在时间区间内的值
  1520. //aDataList := make([]*data_manage.EdbDataList, 0)
  1521. //switch baseEdbInfo.EdbInfoCategoryType {
  1522. //case 0:
  1523. // aDataList, err = data_manage.GetEdbDataList(baseEdbInfo.Source, baseEdbInfo.SubSource, baseEdbInfo.EdbInfoId, startDate, endDate)
  1524. //case 1:
  1525. // _, aDataList, _, _, err, _ = data.GetPredictDataListByPredictEdbInfoId(baseEdbInfo.EdbInfoId, startDate, endDate, false)
  1526. //default:
  1527. // err = errors.New("指标base类型异常")
  1528. // return
  1529. //}
  1530. //
  1531. //// 获取变频指标所有日期的值, 插值法完善数据
  1532. //bDataList := make([]*data_manage.EdbDataList, 0)
  1533. //switch changeEdbInfo.EdbInfoCategoryType {
  1534. //case 0:
  1535. // bDataList, err = data_manage.GetEdbDataList(changeEdbInfo.Source, changeEdbInfo.SubSource, changeEdbInfo.EdbInfoId, "", "")
  1536. //case 1:
  1537. // _, bDataList, _, _, err, _ = data.GetPredictDataListByPredictEdbInfoId(changeEdbInfo.EdbInfoId, "", "", false)
  1538. //default:
  1539. // err = errors.New("指标change类型异常")
  1540. // return
  1541. //}
  1542. //changeDataMap := make(map[string]float64)
  1543. //newChangeDataList, e := HandleDataByLinearRegression(bDataList, changeDataMap)
  1544. //if e != nil {
  1545. // err = fmt.Errorf("获取变频指标插值法Map失败, Err: %s", e.Error())
  1546. // return
  1547. //}
  1548. // 2023-03-17 时间序列始终以指标A为基准, 始终是B进行平移
  1549. baseDataList := make([]*data_manage.EdbDataList, 0)
  1550. baseDataMap := make(map[string]float64)
  1551. changeDataList := make([]*data_manage.EdbDataList, 0)
  1552. changeDataMap := make(map[string]float64)
  1553. // 先把低频指标升频为高频
  1554. {
  1555. frequencyIntMap := map[string]int{
  1556. "日度": 1,
  1557. "周度": 2,
  1558. "旬度": 3,
  1559. "月度": 4,
  1560. "季度": 5,
  1561. "年度": 6,
  1562. }
  1563. // 如果A指标是高频,那么就需要对B指标进行升频
  1564. if frequencyIntMap[frequencyA] < frequencyIntMap[frequencyB] {
  1565. tmpNewChangeDataList, e := HandleDataByLinearRegression(dataListB, changeDataMap)
  1566. if e != nil {
  1567. err = fmt.Errorf("获取变频指标插值法Map失败, Err: %s", e.Error())
  1568. return
  1569. }
  1570. changeDataList = tmpNewChangeDataList
  1571. baseDataList = dataListA
  1572. for _, v := range baseDataList {
  1573. baseDataMap[v.DataTime] = v.Value
  1574. }
  1575. } else if frequencyIntMap[frequencyA] > frequencyIntMap[frequencyB] {
  1576. // 如果B指标是高频,那么就需要对A指标进行升频
  1577. tmpNewChangeDataList, e := HandleDataByLinearRegression(dataListA, baseDataMap)
  1578. if e != nil {
  1579. err = fmt.Errorf("获取变频指标插值法Map失败, Err: %s", e.Error())
  1580. return
  1581. }
  1582. baseDataList = tmpNewChangeDataList
  1583. changeDataList = dataListB
  1584. for _, v := range changeDataList {
  1585. changeDataMap[v.DataTime] = v.Value
  1586. }
  1587. } else {
  1588. baseDataList = dataListA
  1589. for _, v := range baseDataList {
  1590. baseDataMap[v.DataTime] = v.Value
  1591. }
  1592. changeDataList = dataListB
  1593. for _, v := range changeDataList {
  1594. changeDataMap[v.DataTime] = v.Value
  1595. }
  1596. }
  1597. }
  1598. // 计算不领先也不滞后时的相关系数
  1599. baseCalculateData := make([]float64, 0)
  1600. baseDataTimeArr := make([]string, 0)
  1601. for i := range baseDataList {
  1602. baseDataTimeArr = append(baseDataTimeArr, baseDataList[i].DataTime)
  1603. baseCalculateData = append(baseCalculateData, baseDataList[i].Value)
  1604. }
  1605. //zeroBaseData := make([]float64, 0)
  1606. //zeroCalculateData := make([]float64, 0)
  1607. //for i := range baseDataTimeArr {
  1608. // tmpBaseVal, ok1 := baseDataMap[baseDataTimeArr[i]]
  1609. // tmpCalculateVal, ok2 := changeDataMap[baseDataTimeArr[i]]
  1610. // if ok1 && ok2 {
  1611. // zeroBaseData = append(zeroBaseData, tmpBaseVal)
  1612. // zeroCalculateData = append(zeroCalculateData, tmpCalculateVal)
  1613. // }
  1614. //}
  1615. //if len(zeroBaseData) != len(zeroCalculateData) {
  1616. // err = fmt.Errorf("相关系数两组序列元素数不一致, %d-%d", len(baseCalculateData), len(zeroCalculateData))
  1617. // return
  1618. //}
  1619. //zeroRatio := utils.CalculateCorrelationByIntArr(zeroBaseData, zeroCalculateData)
  1620. //if leadValue == 0 {
  1621. // yData = append(yData, zeroRatio)
  1622. //}
  1623. // 计算领先/滞后N期
  1624. if leadValue > 0 {
  1625. // 平移变频指标领先/滞后的日期(单位天)
  1626. moveUnitDays := utils.FrequencyDaysMap[leadUnit]
  1627. for i := range xData {
  1628. //if xData[i] == 0 {
  1629. // yData = append(yData, zeroRatio)
  1630. // continue
  1631. //}
  1632. xCalculateData := make([]float64, 0)
  1633. yCalculateData := make([]float64, 0)
  1634. // 平移指定天数
  1635. mDays := int(moveUnitDays) * xData[i]
  1636. _, dMap := MoveDataDaysToNewDataList(changeDataList, mDays)
  1637. // 取出对应的基准日期的值
  1638. for i2 := range baseDataTimeArr {
  1639. tmpDate := baseDataTimeArr[i2]
  1640. if yVal, ok := dMap[tmpDate]; ok {
  1641. xCalculateData = append(xCalculateData, baseCalculateData[i2])
  1642. yCalculateData = append(yCalculateData, yVal)
  1643. }
  1644. }
  1645. if len(yCalculateData) <= 0 {
  1646. //err = fmt.Errorf("领先滞后相关系数两组序列元素数不一致, %d-%d", len(baseCalculateData), len(yCalculateData))
  1647. //return
  1648. // 领先滞后后,没有可以计算的数据了
  1649. continue
  1650. }
  1651. // 公式计算出领先/滞后频度对应点的区间计算系数
  1652. ratio := utils.CalculateCorrelationByIntArr(xCalculateData, yCalculateData)
  1653. yData = append(yData, ratio)
  1654. }
  1655. }
  1656. xEdbIdValue = xData
  1657. yDataList = make([]data_manage.YData, 0)
  1658. yDate := "0000-00-00"
  1659. yDataList = append(yDataList, data_manage.YData{
  1660. Date: yDate,
  1661. Value: yData,
  1662. })
  1663. return
  1664. }
  1665. // GetFactorChartDataByChartId 获取多因子区间计算图表数据
  1666. func GetFactorChartDataByChartId(chartInfoId int, extraConfig string) (xEdbIdValue []int, yDataList []data_manage.YData, err error) {
  1667. if chartInfoId <= 0 {
  1668. return
  1669. }
  1670. // 指标对应的图例
  1671. extra := new(data_manage.CorrelationChartInfoExtraConfig)
  1672. if extraConfig != "" {
  1673. if e := json.Unmarshal([]byte(extraConfig), extra); e != nil {
  1674. err = fmt.Errorf("解析图表额外配置失败, err: %v", e)
  1675. return
  1676. }
  1677. }
  1678. legends := make(map[string]*data_manage.CorrelationChartLegend)
  1679. if extra != nil {
  1680. for _, v := range extra.LegendConfig {
  1681. s := fmt.Sprintf("%d-%d", v.SeriesId, v.EdbInfoId)
  1682. legends[s] = v
  1683. }
  1684. }
  1685. // 获取图表引用到的系列指标
  1686. chartMappingOb := new(data_manage.FactorEdbSeriesChartMapping)
  1687. cond := fmt.Sprintf(" AND %s = ? AND %s = 1", chartMappingOb.Cols().ChartInfoId, chartMappingOb.Cols().EdbUsed)
  1688. pars := make([]interface{}, 0)
  1689. pars = append(pars, chartInfoId)
  1690. chartMappings, e := chartMappingOb.GetItemsByCondition(cond, pars, []string{}, "")
  1691. if e != nil {
  1692. err = fmt.Errorf("获取图表引用系列指标失败")
  1693. return
  1694. }
  1695. // 取出计算结果
  1696. yDataList = make([]data_manage.YData, 0)
  1697. yDate := "0000-00-00"
  1698. for k, m := range chartMappings {
  1699. var values []data_manage.FactorEdbSeriesCorrelationMatrixValues
  1700. if m.CalculateData != "" {
  1701. e = json.Unmarshal([]byte(m.CalculateData), &values)
  1702. if e != nil {
  1703. err = fmt.Errorf("系列指标计算数据有误, err: %v", e)
  1704. return
  1705. }
  1706. }
  1707. var y []float64
  1708. for _, v := range values {
  1709. if k == 0 {
  1710. xEdbIdValue = append(xEdbIdValue, v.XData)
  1711. }
  1712. y = append(y, v.YData)
  1713. }
  1714. var yData data_manage.YData
  1715. yData.Date = yDate
  1716. yData.Value = y
  1717. yData.SeriesEdb.SeriesId = m.FactorEdbSeriesId
  1718. yData.SeriesEdb.EdbInfoId = m.EdbInfoId
  1719. // 图例
  1720. s := fmt.Sprintf("%d-%d", m.FactorEdbSeriesId, m.EdbInfoId)
  1721. legend := legends[s]
  1722. if legend != nil {
  1723. yData.Name = legend.LegendName
  1724. yData.Color = legend.Color
  1725. }
  1726. yDataList = append(yDataList, yData)
  1727. }
  1728. return
  1729. }
  1730. // FormatChartEdbInfoMappings 补充指标信息
  1731. func FormatChartEdbInfoMappings(chartInfoId int, mappings []*data_manage.ChartEdbInfoMapping) (edbList []*data_manage.ChartEdbInfoMapping, err error) {
  1732. edbList = make([]*data_manage.ChartEdbInfoMapping, 0)
  1733. if len(mappings) == 0 {
  1734. return
  1735. }
  1736. for _, v := range mappings {
  1737. if chartInfoId <= 0 {
  1738. v.IsAxis = 1
  1739. v.LeadValue = 0
  1740. v.LeadUnit = ""
  1741. v.ChartEdbMappingId = 0
  1742. v.ChartInfoId = 0
  1743. v.IsOrder = false
  1744. v.EdbInfoType = 1
  1745. v.ChartStyle = ""
  1746. v.ChartColor = ""
  1747. v.ChartWidth = 0
  1748. } else {
  1749. v.LeadUnitEn = data.GetLeadUnitEn(v.LeadUnit)
  1750. v.LeadUnitEn = data.GetLeadUnitEn(v.LeadUnit)
  1751. }
  1752. v.FrequencyEn = data.GetFrequencyEn(v.Frequency)
  1753. if v.Unit == `无` {
  1754. v.Unit = ``
  1755. }
  1756. edbList = append(edbList, v)
  1757. }
  1758. return
  1759. }*/
  1760. func GetEdbDateByMoveForward(startDate string, moveForward int, edbDataList []*data_manage.EdbDataList) (date string) {
  1761. // 根据日期进行排序
  1762. index := 0
  1763. for _, v := range edbDataList {
  1764. if v.DataTime == startDate {
  1765. index += 1
  1766. }
  1767. if index > 0 {
  1768. index += 1
  1769. }
  1770. if index == moveForward {
  1771. date = v.DataTime
  1772. break
  1773. }
  1774. }
  1775. return
  1776. }
  1777. // HandleEdbDateChange 处理日期变换
  1778. func HandleEdbDateChange(date string, dateChange []*data_manage.EdbDateConfDateChange) (newDate string, err error) {
  1779. newDate = date
  1780. if newDate != "" {
  1781. if len(dateChange) > 0 {
  1782. var dateTime time.Time
  1783. dateTime, err = time.ParseInLocation(utils.FormatDate, newDate, time.Local)
  1784. if err != nil {
  1785. err = fmt.Errorf("日期解析失败: %s", err.Error())
  1786. return
  1787. }
  1788. for _, v := range dateChange {
  1789. if v.ChangeType == 1 {
  1790. dateTime = dateTime.AddDate(v.Year, v.Month, v.Day)
  1791. newDate = dateTime.Format(utils.FormatDate)
  1792. } else if v.ChangeType == 2 {
  1793. newDate, err, _ = utils.HandleSystemAppointDateT(dateTime, v.FrequencyDay, v.Frequency)
  1794. if err != nil {
  1795. return
  1796. }
  1797. dateTime, err = time.ParseInLocation(utils.FormatDate, newDate, time.Local)
  1798. if err != nil {
  1799. err = fmt.Errorf("日期解析失败: %s", err.Error())
  1800. return
  1801. }
  1802. }
  1803. }
  1804. }
  1805. }
  1806. return
  1807. }
  1808. // 添加指标系列和数据
  1809. func AddSeries(edbInfoIds []int, chartInfoId, chartInfoSource int, extraConf data_manage.ChartRangeAnalysisExtraConf, calculatesJson string) (err error) {
  1810. edbArr, e := data_manage.GetEdbInfoByIdList(edbInfoIds)
  1811. if e != nil {
  1812. err = fmt.Errorf("获取指标列表失败, Err: " + e.Error())
  1813. return
  1814. }
  1815. if len(edbArr) == 0 {
  1816. err = fmt.Errorf("获取指标列表失败, 指标不存在")
  1817. return
  1818. }
  1819. edbInfoType := edbArr[0].EdbInfoType
  1820. // 新增指标系列
  1821. seriesItem := new(data_manage.FactorEdbSeries)
  1822. seriesItem.SeriesName = extraConf.SeriesName
  1823. seriesItem.EdbInfoType = edbInfoType
  1824. seriesItem.CreateTime = time.Now().Local()
  1825. seriesItem.ModifyTime = time.Now().Local()
  1826. seriesItem.CalculateState = data_manage.FactorEdbSeriesCalculating
  1827. seriesItem.CalculateStep = calculatesJson
  1828. mappings := make([]*data_manage.FactorEdbSeriesMapping, 0)
  1829. for _, v := range edbArr {
  1830. mappings = append(mappings, &data_manage.FactorEdbSeriesMapping{
  1831. EdbInfoId: v.EdbInfoId,
  1832. EdbCode: v.EdbCode,
  1833. CreateTime: time.Now().Local(),
  1834. ModifyTime: time.Now().Local(),
  1835. })
  1836. }
  1837. seriesId, e := seriesItem.CreateSeriesAndMapping(seriesItem, mappings)
  1838. if e != nil {
  1839. err = fmt.Errorf("新增因子指标系列失败, Err: " + e.Error())
  1840. return
  1841. }
  1842. // 图表关联-此处添加的chart_info_id=0
  1843. seriesChartMapping := new(data_manage.FactorEdbSeriesChartMapping)
  1844. seriesChartMapping.CalculateType = data_manage.FactorEdbSeriesChartCalculateTypeRange
  1845. //新增图表和指标的映射关系
  1846. seriesChartMapping.CalculateData = ""
  1847. seriesChartMapping.FactorEdbSeriesId = seriesId
  1848. seriesChartMapping.ChartInfoId = chartInfoId
  1849. seriesChartMapping.Source = chartInfoSource
  1850. seriesChartMapping.CreateTime = time.Now().Local()
  1851. seriesChartMapping.ModifyTime = time.Now().Local()
  1852. if e = seriesChartMapping.Create(); e != nil {
  1853. err = fmt.Errorf("新增图表关联失败, Err: " + e.Error())
  1854. return
  1855. }
  1856. // todo 计算指标数据并存储
  1857. _, e = FactorEdbStepCalculateRange(seriesId, edbInfoIds, extraConf, false)
  1858. if e != nil {
  1859. err = fmt.Errorf("计算因子指标失败, Err: " + e.Error())
  1860. return
  1861. }
  1862. // 更新系列计算状态
  1863. cols := []string{seriesItem.Cols().CalculateState, seriesItem.Cols().ModifyTime}
  1864. seriesItem.CalculateState = data_manage.FactorEdbSeriesCalculated
  1865. seriesItem.ModifyTime = time.Now().Local()
  1866. if e = seriesItem.Update(cols); e != nil {
  1867. err = fmt.Errorf("更新因子指标系列计算状态失败, Err: " + e.Error())
  1868. return
  1869. }
  1870. return
  1871. }
  1872. func EditSeries(seriesMapping *data_manage.FactorEdbSeriesChartMapping, edbInfoIds []int, extraConf data_manage.ChartRangeAnalysisExtraConf, calculatesJson string, recalculate bool) (err error) {
  1873. seriesOb := new(data_manage.FactorEdbSeries)
  1874. seriesItem, e := seriesOb.GetItemById(seriesMapping.FactorEdbSeriesId)
  1875. if e != nil {
  1876. if e.Error() == utils.ErrNoRow() {
  1877. err = fmt.Errorf("因子指标系列不存在, Err: " + e.Error())
  1878. return
  1879. }
  1880. err = fmt.Errorf("获取因子指标系列失败, Err: " + e.Error())
  1881. return
  1882. }
  1883. edbArr, e := data_manage.GetEdbInfoByIdList(edbInfoIds)
  1884. if e != nil {
  1885. err = fmt.Errorf("获取指标列表失败, Err: " + e.Error())
  1886. return
  1887. }
  1888. if len(edbArr) == 0 {
  1889. err = fmt.Errorf("指标列表为空")
  1890. return
  1891. }
  1892. var calculateResp data_manage.FactorEdbSeriesStepCalculateResp
  1893. calculateResp.SeriesId = seriesItem.FactorEdbSeriesId
  1894. // 如果不需要进行重新计算(比如只改了系列名称)那么只更新指标系列
  1895. seriesItem.SeriesName = extraConf.SeriesName
  1896. seriesItem.EdbInfoType = edbArr[0].EdbInfoType
  1897. seriesItem.ModifyTime = time.Now().Local()
  1898. updateCols := []string{seriesOb.Cols().SeriesName, seriesOb.Cols().EdbInfoType, seriesOb.Cols().ModifyTime}
  1899. if !recalculate {
  1900. if e = seriesItem.Update(updateCols); e != nil {
  1901. err = fmt.Errorf("更新因子指标系列失败, Err: " + e.Error())
  1902. return
  1903. }
  1904. return
  1905. }
  1906. // 更新系列信息和指标关联
  1907. seriesItem.CalculateState = data_manage.FactorEdbSeriesCalculating
  1908. seriesItem.CalculateStep = calculatesJson
  1909. updateCols = append(updateCols, seriesOb.Cols().CalculateState, seriesOb.Cols().CalculateStep)
  1910. mappings := make([]*data_manage.FactorEdbSeriesMapping, 0)
  1911. for _, v := range edbArr {
  1912. mappings = append(mappings, &data_manage.FactorEdbSeriesMapping{
  1913. EdbInfoId: v.EdbInfoId,
  1914. EdbCode: v.EdbCode,
  1915. CreateTime: time.Now().Local(),
  1916. ModifyTime: time.Now().Local(),
  1917. })
  1918. }
  1919. if e = seriesItem.EditSeriesAndMapping(seriesItem, mappings, updateCols); e != nil {
  1920. err = fmt.Errorf("更新因子指标系列信息失败, Err: %s", e.Error())
  1921. return
  1922. }
  1923. // todo 重新计算
  1924. _, e = FactorEdbStepCalculateRange(seriesItem.FactorEdbSeriesId, edbInfoIds, extraConf, false)
  1925. if e != nil {
  1926. err = fmt.Errorf("计算因子指标失败, Err: " + e.Error())
  1927. return
  1928. }
  1929. // 更新系列计算状态
  1930. cols := []string{seriesItem.Cols().CalculateState, seriesItem.Cols().ModifyTime}
  1931. seriesItem.CalculateState = data_manage.FactorEdbSeriesCalculated
  1932. seriesItem.ModifyTime = time.Now().Local()
  1933. if e = seriesItem.Update(cols); e != nil {
  1934. err = fmt.Errorf("更新因子指标系列计算状态失败, Err: %s", e.Error())
  1935. return
  1936. }
  1937. return
  1938. }
  1939. // FactorEdbStepCalculateRange 因子指标-区间计算
  1940. func FactorEdbStepCalculateRange(seriesId int, edbArr []int, extraConf data_manage.ChartRangeAnalysisExtraConf, recalculate bool) (calculateResp data_manage.FactorEdbSeriesStepCalculateResp, err error) {
  1941. // todo 如果指标已保存,则用指标数据还是图表指标数据?
  1942. // 获取图表x轴y轴
  1943. defer func() {
  1944. if err != nil {
  1945. tips := fmt.Sprintf("StepCalculate计算失败, ErrMsg: %v", err)
  1946. fmt.Println(tips)
  1947. utils.FileLog.Info(tips)
  1948. go alarm_msg.SendAlarmMsg(tips, 3)
  1949. }
  1950. /*if len(calculateResp.Fail) > 0 {
  1951. tips := "StepCalculate计算失败, ErrMsg: "
  1952. for _, f := range calculateResp.Fail {
  1953. tips += fmt.Sprintf("code: %s, err: %s\n", f.EdbCode, f.ErrMsg)
  1954. }
  1955. fmt.Println(tips)
  1956. utils.FileLog.Info(tips)
  1957. go alarm_msg.SendAlarmMsg(tips, 2)
  1958. }*/
  1959. }()
  1960. edbInfoMappingList, e := data_manage.GetChartEdbMappingListByEdbInfoIdList(edbArr)
  1961. if e != nil {
  1962. err = fmt.Errorf("获取区间计算图表, A指标mapping信息失败, Err:%v", e)
  1963. return
  1964. }
  1965. _, _, _, err = GetChartDataByEdbInfoList(0, 0, 0, "", "", edbInfoMappingList, &extraConf)
  1966. if err != nil {
  1967. err = fmt.Errorf("获取图表数据失败, ErrMsg: %v", err)
  1968. return
  1969. }
  1970. // 重新计算-先清除原数据
  1971. calculateDataOb := new(data_manage.FactorEdbSeriesCalculateDataQjjs)
  1972. cond := fmt.Sprintf("%s = ?", calculateDataOb.Cols().FactorEdbSeriesId)
  1973. pars := make([]interface{}, 0)
  1974. pars = append(pars, seriesId)
  1975. if e := calculateDataOb.RemoveByCondition(cond, pars); e != nil {
  1976. err = fmt.Errorf("清除原数据失败, err: %v", e)
  1977. return
  1978. }
  1979. // 计算成功的保存结果
  1980. dataArr := make([]*data_manage.FactorEdbSeriesCalculateDataQjjs, 0)
  1981. for _, v := range edbInfoMappingList {
  1982. dataList := v.DataList.([]*data_manage.EdbDataList)
  1983. for _, dataItem := range dataList {
  1984. dataTime, _ := time.ParseInLocation(utils.FormatDate, dataItem.DataTime, time.Local)
  1985. dataArr = append(dataArr, &data_manage.FactorEdbSeriesCalculateDataQjjs{
  1986. FactorEdbSeriesId: seriesId,
  1987. EdbInfoId: v.EdbInfoId,
  1988. EdbCode: v.EdbCode,
  1989. DataTime: dataTime,
  1990. Value: dataItem.Value,
  1991. CreateTime: time.Now().Local(),
  1992. ModifyTime: time.Now().Local(),
  1993. DataTimestamp: dataItem.DataTimestamp,
  1994. })
  1995. }
  1996. }
  1997. if len(dataArr) == 0 {
  1998. err = fmt.Errorf("计算结果无数据, seriesId: %d", seriesId)
  1999. return
  2000. }
  2001. if e = calculateDataOb.CreateMulti(dataArr); e != nil {
  2002. err = fmt.Errorf("保存计算结果失败, seriesId: %d, err: %v, ", seriesId, e)
  2003. return
  2004. }
  2005. return
  2006. }
  2007. func CheckChartRangeExtraConfig(extraConfig data_manage.ChartRangeAnalysisExtraConf) (err error, errMsg string, isSendEmail bool) {
  2008. extraConfig.SeriesName = strings.TrimSpace(extraConfig.SeriesName)
  2009. if extraConfig.SeriesName == "" && extraConfig.EdbInfoMode == 1 {
  2010. errMsg = "请输入指标系列名称"
  2011. err = errors.New(errMsg)
  2012. isSendEmail = false
  2013. return
  2014. }
  2015. if extraConfig.CalculateType > 5 || extraConfig.CalculateType < 0 {
  2016. errMsg = "计算方式参数错误"
  2017. err = errors.New(errMsg)
  2018. isSendEmail = false
  2019. return
  2020. }
  2021. switch extraConfig.DateRangeType {
  2022. case 0:
  2023. case 1:
  2024. if len(extraConfig.ManualDateConf) == 0 {
  2025. errMsg = "请选择时间区间"
  2026. err = errors.New(errMsg)
  2027. return
  2028. }
  2029. // 先按开始时间排序
  2030. sort.Sort(data_manage.ChartRangeAnalysisManualDateConfList(extraConfig.ManualDateConf))
  2031. // 校验日期
  2032. // 1.如果截止时间小于指标的截止日期,需要重置为指标的截止日期
  2033. // 2.时间区间不能重叠
  2034. for i := 1; i < len(extraConfig.ManualDateConf); i++ {
  2035. start1, e := time.Parse(utils.FormatDate, extraConfig.ManualDateConf[i-1].EndDate)
  2036. if e != nil {
  2037. err = e
  2038. errMsg = "截止日期格式有误"
  2039. return
  2040. }
  2041. start2, e := time.Parse(utils.FormatDate, extraConfig.ManualDateConf[i].EndDate)
  2042. if e != nil {
  2043. err = e
  2044. errMsg = "截止日期格式有误"
  2045. return
  2046. }
  2047. start3, e := time.Parse(utils.FormatDate, extraConfig.ManualDateConf[i].StartDate)
  2048. if e != nil {
  2049. err = e
  2050. errMsg = "截止日期格式有误"
  2051. return
  2052. }
  2053. // 如果当前区间的开始时间小于等于前一个区间的结束时间,则存在重叠
  2054. if !start2.After(start1) || start3.Before(start1) {
  2055. errMsg = "日期区间存在重叠"
  2056. return
  2057. }
  2058. }
  2059. //如果截止时间大于指标的截止日期,需要重置为指标的截止日期
  2060. case 2:
  2061. if extraConfig.YearDateConf.StartDay == "" || extraConfig.YearDateConf.EndDay == "" {
  2062. errMsg = "请选择时间区间"
  2063. return
  2064. }
  2065. if _, e := time.Parse(utils.FormatMonthDay, extraConfig.YearDateConf.StartDay); e != nil {
  2066. errMsg = "开始日期格式有误"
  2067. return
  2068. }
  2069. if _, e := time.Parse(utils.FormatMonthDay, extraConfig.YearDateConf.EndDay); e != nil {
  2070. errMsg = "结束日期格式有误"
  2071. return
  2072. }
  2073. }
  2074. return
  2075. }