edb_info.go 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418
  1. package data
  2. import (
  3. "context"
  4. "errors"
  5. "fmt"
  6. "hongze/hongze_task/models/data_manage"
  7. "hongze/hongze_task/utils"
  8. "rdluck_tools/http"
  9. "strconv"
  10. "sync"
  11. "time"
  12. )
  13. //刷新同花顺数据
  14. func RefreshDataFromThs(wg *sync.WaitGroup) (err error) {
  15. defer func() {
  16. if err != nil {
  17. fmt.Println("RefreshDataFromThs Err:" + err.Error())
  18. go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "RefreshDataFromThs ErrMsg:"+err.Error(), utils.EmailSendToUsers)
  19. }
  20. }()
  21. var condition string
  22. var pars []interface{}
  23. condition += " AND source=? "
  24. pars = append(pars, utils.DATA_SOURCE_THS)
  25. items, err := data_manage.GetEdbInfoByCondition(condition, pars)
  26. if err != nil {
  27. return errors.New("GetEdbInfoByCondition:" + err.Error())
  28. }
  29. now := time.Now()
  30. var endDate string
  31. if now.Hour() == 0 {
  32. endDate = time.Now().AddDate(0, 0, -1).Format(utils.FormatDate)
  33. } else {
  34. endDate = time.Now().Format(utils.FormatDate)
  35. }
  36. for _, v := range items {
  37. startDate := ""
  38. if v.Frequency == "日度" {
  39. startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
  40. } else if v.Frequency == "周度" {
  41. startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
  42. } else if v.Frequency == "月度" {
  43. startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
  44. } else if v.Frequency == "季度" {
  45. startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
  46. } else if v.Frequency == "年度" {
  47. startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
  48. } else {
  49. startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
  50. }
  51. err = SyncEdbDataByThs(int64(v.EdbInfoId), v.EdbCode, startDate, endDate)
  52. if err != nil {
  53. return errors.New("SyncEdbDataByThs:" + err.Error())
  54. }
  55. item, err := data_manage.GetEdbInfoMaxAndMinInfo(v.Source, v.EdbCode)
  56. if err != nil {
  57. return err
  58. }
  59. if item != nil {
  60. err = data_manage.ModifyEdbInfoMaxAndMinInfo(v.EdbInfoId, item)
  61. if err != nil {
  62. return err
  63. }
  64. }
  65. //minDate, maxDate, err := data.GetEdbDataThsMaxOrMinDate(v.EdbInfoId)
  66. //if err != nil {
  67. // return errors.New("GetEdbDataThsMaxOrMinDate:" + err.Error())
  68. //}
  69. //fmt.Println("minDate:" + minDate + ";maxDate:" + maxDate)
  70. //err = data.ModifyEdbDataInfoDate(v.EdbInfoId, maxDate)
  71. //if err != nil {
  72. // return errors.New("ModifyEdbDataInfoDate:" + err.Error())
  73. //}
  74. }
  75. wg.Done()
  76. return err
  77. }
  78. //刷新万得数据
  79. func RefreshDataFromWind(wg *sync.WaitGroup) (err error) {
  80. defer func() {
  81. if err != nil {
  82. fmt.Println("RefreshDataFromWind Err:" + err.Error())
  83. go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "RefreshDataFromWind ErrMsg:"+err.Error(), utils.EmailSendToUsers)
  84. }
  85. }()
  86. var condition string
  87. var pars []interface{}
  88. condition += " AND source=? "
  89. pars = append(pars, utils.DATA_SOURCE_WIND)
  90. items, err := data_manage.GetEdbInfoByCondition(condition, pars)
  91. if err != nil {
  92. return err
  93. }
  94. now := time.Now()
  95. var endDate string
  96. if now.Hour() == 0 {
  97. endDate = time.Now().AddDate(0, 0, -1).Format(utils.FormatDate)
  98. } else {
  99. endDate = time.Now().Format(utils.FormatDate)
  100. }
  101. for _, v := range items {
  102. startDate := ""
  103. if v.Frequency == "日度" {
  104. startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
  105. } else if v.Frequency == "周度" {
  106. startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
  107. } else if v.Frequency == "月度" {
  108. startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
  109. } else if v.Frequency == "季度" {
  110. startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
  111. } else if v.Frequency == "年度" {
  112. startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
  113. } else {
  114. startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
  115. }
  116. err = SyncEdbDataByWind(int64(v.EdbInfoId), v.EdbCode, startDate, endDate)
  117. if err != nil {
  118. return err
  119. }
  120. item, err := data_manage.GetEdbInfoMaxAndMinInfo(v.Source, v.EdbCode)
  121. if err != nil {
  122. return err
  123. }
  124. if item != nil {
  125. err = data_manage.ModifyEdbInfoMaxAndMinInfo(v.EdbInfoId, item)
  126. if err != nil {
  127. return err
  128. }
  129. }
  130. }
  131. wg.Done()
  132. return err
  133. }
  134. //刷新彭博数据
  135. func RefreshDataFromPb(wg *sync.WaitGroup) (err error) {
  136. defer func() {
  137. if err != nil {
  138. fmt.Println("RefreshDataFromPb Err:" + err.Error())
  139. go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "RefreshDataFromPb ErrMsg:"+err.Error(), utils.EmailSendToUsers)
  140. }
  141. }()
  142. var condition string
  143. var pars []interface{}
  144. condition += " AND source=? "
  145. pars = append(pars, utils.DATA_SOURCE_PB)
  146. items, err := data_manage.GetEdbInfoByCondition(condition, pars)
  147. if err != nil {
  148. return errors.New("GetEdbInfoByCondition:" + err.Error())
  149. }
  150. now := time.Now()
  151. var endDate string
  152. if now.Hour() == 0 {
  153. endDate = time.Now().AddDate(0, 0, -1).Format(utils.FormatDateUnSpace)
  154. } else {
  155. endDate = time.Now().Format(utils.FormatDateUnSpace)
  156. }
  157. for _, v := range items {
  158. startDate := ""
  159. if v.Frequency == "日度" {
  160. startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
  161. } else if v.Frequency == "周度" {
  162. startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
  163. } else if v.Frequency == "月度" {
  164. startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
  165. } else if v.Frequency == "季度" {
  166. startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
  167. } else if v.Frequency == "年度" {
  168. startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
  169. } else {
  170. startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
  171. }
  172. fmt.Println(startDate, endDate)
  173. err = SyncEdbDataByPb(int64(v.EdbInfoId), v.EdbCode, startDate, endDate)
  174. if err != nil {
  175. return errors.New("SyncEdbDataByPb:" + err.Error())
  176. }
  177. item, err := data_manage.GetEdbInfoMaxAndMinInfo(v.Source, v.EdbCode)
  178. if err != nil {
  179. return err
  180. }
  181. if item != nil {
  182. err = data_manage.ModifyEdbInfoMaxAndMinInfo(v.EdbInfoId, item)
  183. if err != nil {
  184. return err
  185. }
  186. }
  187. //minDate, maxDate, err := data.GetEdbDataPbMaxOrMinDate(v.EdbInfoId)
  188. //if err != nil {
  189. // return errors.New("GetEdbDataThsMaxOrMinDate:" + err.Error())
  190. //}
  191. //fmt.Println("minDate:" + minDate + ";maxDate:" + maxDate)
  192. //err = data.ModifyEdbDataInfoDate(v.EdbInfoId, maxDate)
  193. //if err != nil {
  194. // return errors.New("ModifyEdbDataInfoDate:" + err.Error())
  195. //}
  196. }
  197. wg.Done()
  198. return err
  199. }
  200. func CheckDataInterface(cont context.Context) (err error) {
  201. go func() {
  202. checkUrl := utils.Hz_Data_Url + `hz_server`
  203. body, err := http.Get(checkUrl)
  204. if err != nil {
  205. go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"检测数据接口:失败提醒", "CheckDataInterface ErrMsg:"+err.Error(), utils.EmailSendToUsers)
  206. }
  207. result := string(body)
  208. if result != "1" {
  209. go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"检测数据接口:失败提醒", "CheckDataInterface ErrMsg:"+string(body), utils.EmailSendToUsers)
  210. }
  211. }()
  212. return
  213. }
  214. func CheckPbDataInterface(cont context.Context) (err error) {
  215. go func() {
  216. checkUrl := utils.Hz_Data_PB_Url + `hz_server`
  217. body, err := http.Get(checkUrl)
  218. if err != nil {
  219. go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"检测数据接口:失败提醒", "CheckPbDataInterface ErrMsg:"+err.Error(), utils.EmailSendToUsers)
  220. }
  221. result := string(body)
  222. if result != "1" {
  223. go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"检测数据接口:失败提醒", "CheckPbDataInterface ErrMsg:"+string(body), utils.EmailSendToUsers)
  224. }
  225. }()
  226. return
  227. }
  228. //刷新所有计算指标
  229. func RefreshDataFromCalculateAll() (err error) {
  230. defer func() {
  231. if err != nil {
  232. utils.FileLog.Info("RefreshDataFromCalculateAll Err:" + err.Error())
  233. go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "RefreshDataFromCalculateAll ErrMsg:"+err.Error(), utils.EmailSendToUsers)
  234. }
  235. }()
  236. var condition string
  237. var pars []interface{}
  238. condition += " AND edb_type=? "
  239. pars = append(pars, 2)
  240. items, err := data_manage.GetEdbInfoByCondition(condition, pars)
  241. if err != nil {
  242. return err
  243. }
  244. for _, v := range items {
  245. edbInfoId := v.EdbInfoId
  246. edbCode := v.EdbCode
  247. if v.Source == utils.DATA_SOURCE_CALCULATE {
  248. startDate := ""
  249. if v.Frequency == "日度" {
  250. startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
  251. } else if v.Frequency == "周度" {
  252. startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
  253. } else if v.Frequency == "月度" {
  254. startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
  255. } else if v.Frequency == "季度" {
  256. startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
  257. } else if v.Frequency == "年度" {
  258. startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
  259. } else {
  260. startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
  261. }
  262. endDate := time.Now().Format(utils.FormatDate)
  263. var edbInfoIdBytes []string
  264. calculateMap, err := data_manage.GetEdbInfoCalculateDetail(int(v.EdbInfoId))
  265. if err != nil {
  266. return errors.New("GetEdbInfoCalculateDetail Err:" + err.Error())
  267. }
  268. var formulaStr string
  269. edbInfoList := make([]*data_manage.EdbInfo, 0)
  270. for _, v := range calculateMap {
  271. formulaStr += v.FromTag + ","
  272. edbInfoIdBytes = append(edbInfoIdBytes, v.FromTag)
  273. edbInfo, _ := data_manage.GetEdbInfoById(v.FromEdbInfoId)
  274. edbInfoList = append(edbInfoList, edbInfo)
  275. }
  276. fmt.Println("RefreshCalculate:",edbInfoList, edbInfoId, edbCode, v.CalculateFormula, startDate, endDate, edbInfoIdBytes)
  277. err = RefreshCalculate(edbInfoList, edbInfoId, edbCode, v.CalculateFormula, startDate, endDate, edbInfoIdBytes)
  278. if err != nil {
  279. return errors.New("RefreshCalculate Err:" + err.Error())
  280. }
  281. } else if v.Source == utils.DATA_SOURCE_CALCULATE_LJZZY {
  282. calculateLjzzy, err := data_manage.GetEdbInfoCalculateLjzzyDetail(edbInfoId)
  283. if err != nil {
  284. return errors.New("GetEdbInfoCalculateLjzzyDetail Err:" + err.Error())
  285. }
  286. fromEdbInfo, err := data_manage.GetEdbInfoById(calculateLjzzy.FromEdbInfoId)
  287. if err != nil {
  288. return errors.New("GetEdbInfoById Err:" + err.Error())
  289. }
  290. year := time.Now().Year() - 1
  291. startDate := strconv.Itoa(year) + "-01" + "-01"
  292. endDate := time.Now().Format(utils.FormatDate)
  293. err = data_manage.RefreshCalculateLjzzy(edbInfoId, fromEdbInfo, edbCode, startDate, endDate)
  294. if err != nil {
  295. return errors.New("RefreshCalculateLjzzy Err:" + err.Error())
  296. }
  297. } else if v.Source == utils.DATA_SOURCE_CALCULATE_TBZ {
  298. calculateTbz, err := data_manage.GetEdbInfoCalculateTbzDetail(edbInfoId)
  299. if err != nil {
  300. return errors.New("GetEdbInfoCalculateTbzDetail Err:" + err.Error())
  301. }
  302. fromEdbInfo, err := data_manage.GetEdbInfoById(calculateTbz.FromEdbInfoId)
  303. if err != nil {
  304. return errors.New("GetEdbInfoById Err:" + err.Error())
  305. }
  306. startDate := time.Now().AddDate(-2, -2, 0).Format(utils.FormatDate)
  307. endDate := time.Now().Format(utils.FormatDate)
  308. err = data_manage.RefreshCalculateTbz(edbInfoId, fromEdbInfo, calculateTbz.EdbCode, startDate, endDate)
  309. if err != nil {
  310. return errors.New("RefreshCalculateTbz Err:" + err.Error())
  311. }
  312. } else if v.Source == utils.DATA_SOURCE_CALCULATE_TCZ {
  313. calculateTcz, err := data_manage.GetEdbInfoCalculateTczDetail(edbInfoId)
  314. if err != nil {
  315. return errors.New("GetEdbInfoCalculateTczDetail Err:" + err.Error())
  316. }
  317. fromEdbInfo, err := data_manage.GetEdbInfoById(calculateTcz.FromEdbInfoId)
  318. if err != nil {
  319. return errors.New("GetEdbInfoById Err:" + err.Error())
  320. }
  321. startDate := time.Now().AddDate(-2, -2, 0).Format(utils.FormatDate)
  322. endDate := time.Now().Format(utils.FormatDate)
  323. err = data_manage.RefreshCalculateTcz(edbInfoId, fromEdbInfo, calculateTcz.EdbCode, startDate, endDate)
  324. if err != nil {
  325. return errors.New("RefreshCalculateTcz Err:" + err.Error())
  326. }
  327. } else if v.Source == utils.DATA_SOURCE_CALCULATE_NSZYDPJJS {
  328. calculateNszydpjjs, err := data_manage.GetEdbInfoCalculateNszydpjjsDetail(edbInfoId)
  329. if err != nil {
  330. return errors.New("GetEdbInfoCalculateNszydpjjsDetail Err:" + err.Error())
  331. }
  332. fromEdbInfo, err := data_manage.GetEdbInfoById(calculateNszydpjjs.FromEdbInfoId)
  333. if err != nil {
  334. return errors.New("GetEdbInfoById Err:" + err.Error())
  335. }
  336. formulaInt, _ := strconv.Atoi(v.CalculateFormula)
  337. err = data_manage.RefreshCalculateNszydpjjs(edbInfoId, v.Source, formulaInt, fromEdbInfo, calculateNszydpjjs.EdbCode)
  338. if err != nil {
  339. return errors.New("RefreshCalculateNszydpjjs Err:" + err.Error())
  340. }
  341. } else {
  342. msg := "刷新失败,无效的指标渠道"
  343. err = errors.New(msg)
  344. return err
  345. }
  346. }
  347. return err
  348. }
  349. //刷新手工指标数据
  350. func RefreshDataFromManual(wg *sync.WaitGroup) (err error) {
  351. defer func() {
  352. if err != nil {
  353. fmt.Println("RefreshDataFromManual Err:" + err.Error())
  354. go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "RefreshDataFromManual ErrMsg:"+err.Error(), utils.EmailSendToUsers)
  355. }
  356. }()
  357. var condition string
  358. var pars []interface{}
  359. condition += " AND source=? "
  360. pars = append(pars, utils.DATA_SOURCE_MANUAL)
  361. items, err := data_manage.GetEdbInfoByCondition(condition, pars)
  362. if err != nil {
  363. return errors.New("GetEdbInfoByCondition:" + err.Error())
  364. }
  365. now := time.Now()
  366. var endDate string
  367. if now.Hour() == 0 {
  368. endDate = time.Now().AddDate(0, 0, -1).Format(utils.FormatDate)
  369. } else {
  370. endDate = time.Now().Format(utils.FormatDate)
  371. }
  372. for _, v := range items {
  373. startDate := ""
  374. if v.Frequency == "日度" {
  375. startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
  376. } else if v.Frequency == "周度" {
  377. startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
  378. } else if v.Frequency == "月度" {
  379. startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
  380. } else if v.Frequency == "季度" {
  381. startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
  382. } else if v.Frequency == "年度" {
  383. startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
  384. } else {
  385. startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
  386. }
  387. err = data_manage.RefreshManual(v.EdbInfoId, v.EdbCode, startDate, endDate)
  388. if err != nil {
  389. return errors.New("SyncEdbDataByThs:" + err.Error())
  390. }
  391. item, err := data_manage.GetEdbInfoMaxAndMinInfo(v.Source, v.EdbCode)
  392. if err != nil {
  393. return err
  394. }
  395. if item != nil {
  396. err = data_manage.ModifyEdbInfoMaxAndMinInfo(v.EdbInfoId, item)
  397. if err != nil {
  398. return err
  399. }
  400. }
  401. }
  402. wg.Done()
  403. return err
  404. }