chart_info.go 60 KB

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