trade_position_analysis.go 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588
  1. package data
  2. import (
  3. "context"
  4. "fmt"
  5. "hongze/hongze_task/models/data_manage"
  6. "hongze/hongze_task/services/alarm_msg"
  7. "hongze/hongze_task/utils"
  8. "sort"
  9. "strconv"
  10. "time"
  11. )
  12. // InitPositionTask 统计今日交易所的持仓分析数据
  13. func InitPositionTask(cont context.Context) (err error) {
  14. exchanges := []string{"zhengzhou", "dalian", "shanghai", "cffex", "ine"} //郑商所,大商所,上期所,中金所,上期能源
  15. startDate := time.Now().Format(utils.FormatDate)
  16. endDate := startDate
  17. for _, v := range exchanges {
  18. exchange := v
  19. err = nil
  20. fmt.Println("InitPositionTask: 启动:" + exchange)
  21. utils.FileLog.Info("InitPositionTask: 启动:" + exchange)
  22. fmt.Println("开始" + startDate + "结束" + endDate)
  23. utils.FileLog.Info(fmt.Sprintf("InitTradePosition:开始:%s; 结束:%s", startDate, endDate))
  24. tErr, errMsg := InitTradePosition(exchange, startDate, endDate)
  25. if tErr != nil {
  26. err = tErr
  27. fmt.Println("InitTradePosition: 操作失败:" + errMsg + tErr.Error())
  28. utils.FileLog.Info(fmt.Sprintf("InitTradePosition: 操作失败:%s:%s", errMsg, tErr.Error()))
  29. continue
  30. }
  31. fmt.Println("InitTradePosition:" + exchange + "已完成")
  32. utils.FileLog.Info("InitTradePosition:" + exchange + "已完成")
  33. }
  34. return
  35. }
  36. func InitTradePosition(exchange, startDate, endDate string) (err error, errMsg string) {
  37. defer func() {
  38. if err != nil {
  39. tips := fmt.Sprintf("统计今日交易所的持仓分析数据失败, Exchange: %s, Err: %s, Msg: %s", exchange, err.Error(), errMsg)
  40. alarm_msg.SendAlarmMsg(tips, 3)
  41. }
  42. }()
  43. // 批量插入今日的初始值
  44. num, err := data_manage.GetTradePositionTopCountByExchangeDataTime(exchange, startDate, endDate)
  45. if err != nil {
  46. errMsg = "查询原始数据失败,GetTradePositionTopCountByExchangeDataTime() Err: "
  47. return
  48. }
  49. if num > 0 {
  50. //err = fmt.Errorf("数据已存在,无需处理")
  51. return
  52. }
  53. err = data_manage.MultiInsertTradeBaseDataToTop(exchange, startDate, endDate)
  54. if err != nil {
  55. errMsg = "新增原始数据失败,MultiInsertTradeBaseDataToTop() Err: "
  56. return
  57. }
  58. originList, err := data_manage.GetTradePositionTopByExchangeDataTime(exchange, startDate, endDate)
  59. if err != nil {
  60. errMsg = "查询原始数据失败, GetTradePositionTopByExchangeDataTime() Err: "
  61. return
  62. }
  63. if len(originList) <= 0 {
  64. // 忽略周末
  65. w := time.Now().Weekday().String()
  66. if w == "Saturday" || w == "Sunday" {
  67. return
  68. }
  69. // 每天最后一个小时执行依旧无数据时, 才进行邮件提示
  70. if time.Now().Hour() != 23 {
  71. return
  72. }
  73. err = fmt.Errorf("原始数据没有值")
  74. return
  75. }
  76. // 原始数据日期
  77. dates, e := data_manage.GetTradePositionTopOriginDataTimes(exchange)
  78. if e != nil {
  79. err = fmt.Errorf("GetTradePositionTopOriginDataTimes err: %s", e.Error())
  80. return
  81. }
  82. now := time.Now()
  83. dataTimeMap := make(map[string]*data_manage.TradePositionTop)
  84. onlyEmptyMap := make(map[string]bool)
  85. onlyEmptyNameMap := make(map[string]*data_manage.TradePositionTop)
  86. topLastMap := make(map[string]int)
  87. topLastRankMap := make(map[string]int)
  88. list := make([]*data_manage.TradePositionTop, 0)
  89. for _, v := range originList {
  90. tmp0, tmpErr := dealTradeOriginData(dataTimeMap, onlyEmptyMap, onlyEmptyNameMap, v, topLastMap, topLastRankMap, startDate, now, dates)
  91. if tmpErr != nil {
  92. err = tmpErr
  93. errMsg = "处理原始数据失败 dealTradeOriginData() Err: "
  94. return
  95. }
  96. if tmp0 != nil {
  97. list = append(list, tmp0)
  98. }
  99. if len(list) >= 1000 {
  100. err = data_manage.InsertMultiTradePositionTop(exchange, list)
  101. if err != nil {
  102. errMsg = "批量新增昨日数据失败,InsertMultiTradePositionTop() Err: "
  103. return
  104. }
  105. list = make([]*data_manage.TradePositionTop, 0)
  106. }
  107. }
  108. if len(list) > 0 {
  109. err = data_manage.InsertMultiTradePositionTop(exchange, list)
  110. if err != nil {
  111. errMsg = "批量新增昨日数据失败,InsertMultiTradePositionTop() Err: "
  112. return
  113. }
  114. list = make([]*data_manage.TradePositionTop, 0)
  115. }
  116. // 处理某个期货公司只有买单没有卖单,或者只有卖单没有买单的情况
  117. for k, v := range onlyEmptyNameMap {
  118. _, ok1 := onlyEmptyMap[k+"_1"]
  119. _, ok2 := onlyEmptyMap[k+"_2"]
  120. var dealType int
  121. if ok1 && !ok2 {
  122. dealType = 2 //只有买单没有卖单
  123. } else if !ok1 && ok2 {
  124. dealType = 1 //只有卖单没有买单的情况
  125. } else {
  126. continue
  127. }
  128. if dealType > 0 {
  129. str := v.ClassifyName + "_" + v.ClassifyType + "_" + v.DataTime + "_" + strconv.Itoa(dealType)
  130. dealValue := 0
  131. if lastVal, ok := topLastMap[str]; ok {
  132. dealValue = int(float64(lastVal)*0.7 + 0.5)
  133. }
  134. tmp := &data_manage.TradePositionTop{
  135. ClassifyName: v.ClassifyName,
  136. ClassifyType: v.ClassifyType,
  137. DealShortName: v.DealShortName,
  138. DataTime: v.DataTime,
  139. DealValue: dealValue,
  140. CreateTime: now,
  141. ModifyTime: now,
  142. DealType: dealType,
  143. SourceType: 2,
  144. }
  145. list = append(list, tmp)
  146. if len(list) >= 1000 {
  147. err = data_manage.InsertMultiTradePositionTop(exchange, list)
  148. if err != nil {
  149. errMsg = "批量新增前日数据失败,InsertMultiTradePositionTop() Err: "
  150. return
  151. }
  152. list = make([]*data_manage.TradePositionTop, 0)
  153. }
  154. }
  155. }
  156. if len(list) > 0 {
  157. err = data_manage.InsertMultiTradePositionTop(exchange, list)
  158. if err != nil {
  159. errMsg = "批量新增前日数据失败,InsertMultiTradePositionTop() Err: "
  160. return
  161. }
  162. }
  163. //生成净多单,净空单榜单
  164. err = createAnalysisCleanTop(exchange, startDate, endDate)
  165. if err != nil {
  166. errMsg = "创建净多单,净空单数据失败,createAnalysisCleanTop() Err: "
  167. return
  168. }
  169. // 特殊处理起始日期前一天的数据
  170. err = DealYesterdayData(exchange, startDate)
  171. if err != nil {
  172. errMsg = "处理昨日数据失败,DealYesterdayData() Err: "
  173. return
  174. }
  175. return
  176. }
  177. func dealTradeOriginData(dataTimeMap map[string]*data_manage.TradePositionTop, onlyEmptyMap map[string]bool, onlyEmptyNameMap map[string]*data_manage.TradePositionTop, currentItem *data_manage.TradePositionTop, topLastMap map[string]int, topLastRankMap map[string]int, startDate string, now time.Time, dates []string) (tmp0 *data_manage.TradePositionTop, err error) {
  178. classifyName := currentItem.ClassifyName
  179. classifyType := currentItem.ClassifyType
  180. dealShortName := currentItem.DealShortName
  181. dealValue := currentItem.DealValue
  182. dealChange := currentItem.DealChange
  183. dataTime := currentItem.DataTime
  184. dealType := currentItem.DealType
  185. dealTypeStr := strconv.Itoa(dealType)
  186. dataTimeMap[classifyName+"_"+classifyType+"_"+dealTypeStr+"_"+dealShortName+"_"+dataTime] = currentItem
  187. onlyEmptyMap[classifyName+"_"+classifyType+"_"+dataTime+"_"+dealShortName+"_"+dealTypeStr] = true
  188. onlyEmptyNameMap[classifyName+"_"+classifyType+"_"+dataTime+"_"+dealShortName] = currentItem
  189. if currentItem.Rank > topLastRankMap[classifyName+"_"+classifyType+"_"+dataTime+"_"+dealTypeStr] {
  190. topLastMap[classifyName+"_"+classifyType+"_"+dataTime+"_"+dealTypeStr] = dealValue
  191. topLastRankMap[classifyName+"_"+classifyType+"_"+dataTime+"_"+dealTypeStr] = currentItem.Rank
  192. }
  193. if dataTime > startDate {
  194. //tmpTimeStr, tErr := getYesterdayDate(dataTime)
  195. //if tErr != nil {
  196. // err = tErr
  197. // return
  198. //}
  199. tmpTimeStr := getPrevTradeDataDate(dataTime, dates)
  200. if tmpTimeStr < startDate {
  201. return
  202. }
  203. // 判断T-1日是否有值, 如果T-1日为空,则根据T日的值计算出T-1的值
  204. if _, ok := dataTimeMap[classifyName+"_"+classifyType+"_"+dealTypeStr+"_"+dealShortName+"_"+tmpTimeStr]; !ok {
  205. yesterdayVal := dealValue - dealChange
  206. yesterdayChange := 0
  207. //beforeYesterday, _ := getYesterdayDate(tmpTimeStr)
  208. beforeYesterday := getPrevTradeDataDate(tmpTimeStr, dates)
  209. beforeYesterdayItem, ok1 := dataTimeMap[classifyName+"_"+classifyType+"_"+dealTypeStr+"_"+dealShortName+"_"+beforeYesterday]
  210. if ok1 {
  211. yesterdayChange = yesterdayVal - beforeYesterdayItem.DealValue
  212. }
  213. tmp0 = &data_manage.TradePositionTop{
  214. ClassifyName: classifyName,
  215. ClassifyType: classifyType,
  216. DealShortName: dealShortName,
  217. DealValue: yesterdayVal,
  218. DealChange: yesterdayChange,
  219. DataTime: tmpTimeStr,
  220. CreateTime: now,
  221. ModifyTime: now,
  222. DealType: dealType,
  223. SourceType: 1,
  224. }
  225. dataTimeMap[classifyName+"_"+classifyType+"_"+dealTypeStr+"_"+dealShortName+"_"+tmpTimeStr] = tmp0
  226. onlyEmptyMap[classifyName+"_"+classifyType+"_"+tmpTimeStr+"_"+dealShortName+"_"+dealTypeStr] = true
  227. onlyEmptyNameMap[classifyName+"_"+classifyType+"_"+tmpTimeStr+"_"+dealShortName] = tmp0
  228. }
  229. }
  230. return
  231. }
  232. // DealYesterdayData 更新昨日数据
  233. func DealYesterdayData(exchange, startDate string) (err error) {
  234. // 查询最早的日期
  235. firstItem, err := data_manage.GetFirstBaseFromTradeIndexByDate(exchange)
  236. if err != nil {
  237. return
  238. }
  239. if startDate == firstItem.DataTime { //如果当前是起始日,则无需统计修改前一天的数据
  240. return
  241. }
  242. // 前一个交易日, 前两个交易日
  243. dates, e := data_manage.GetTradePositionTopOriginDataTimes(exchange)
  244. if e != nil {
  245. err = fmt.Errorf("GetTradePositionTopOriginDataTimes err: %s", e.Error())
  246. return
  247. }
  248. yesterdayStr := getPrevTradeDataDate(startDate, dates)
  249. beforeYesterdayStr := getPrevTradeDataDate(yesterdayStr, dates)
  250. //yesterdayStr, err := getYesterdayDate(startDate)
  251. //if err != nil {
  252. // return
  253. //}
  254. ////查找前日的值,并更新对应的更改
  255. //beforeYesterdayStr, err := getYesterdayDate(yesterdayStr)
  256. //if err != nil {
  257. // return
  258. //}
  259. // 先查出T日最原始的数据
  260. originList, err := data_manage.GetTradePositionTopByExchangeDataTime(exchange, startDate, startDate)
  261. if err != nil {
  262. return
  263. }
  264. originBuyMap := make(map[string]*data_manage.TradePositionTop)
  265. originSoldMap := make(map[string]*data_manage.TradePositionTop)
  266. for _, v := range originList {
  267. if v.SourceType != 0 {
  268. continue
  269. }
  270. str := v.ClassifyName + "_" + v.ClassifyType + "_" + v.DealShortName
  271. if v.DealType == 1 {
  272. originBuyMap[str] = v
  273. } else if v.DealType == 2 {
  274. originSoldMap[str] = v
  275. }
  276. }
  277. // 然后查询T-1中数据来源类型是2的数据
  278. changeList, err := data_manage.GetTradePositionTopByExchangeSourceType(exchange, yesterdayStr, 2)
  279. if err != nil {
  280. return
  281. }
  282. if len(changeList) <= 0 {
  283. //err = fmt.Errorf("前天的数据无需修改")
  284. return
  285. }
  286. // 查询出前日的成交量
  287. beforeYesterdayList, err := data_manage.GetTradePositionTopByExchangeDataTime(exchange, beforeYesterdayStr, beforeYesterdayStr)
  288. if err != nil {
  289. return
  290. }
  291. beforeYesterdayMap1 := make(map[string]int)
  292. beforeYesterdayMap2 := make(map[string]int)
  293. if len(beforeYesterdayList) > 0 {
  294. for _, v := range beforeYesterdayList {
  295. if v.SourceType == 2 {
  296. continue
  297. }
  298. str := v.ClassifyName + "_" + v.ClassifyType + "_" + v.DealShortName
  299. if v.DealType == 1 {
  300. beforeYesterdayMap1[str] = v.DealValue
  301. } else if v.DealType == 2 {
  302. beforeYesterdayMap2[str] = v.DealValue
  303. }
  304. }
  305. }
  306. // 根据原始数据中的值推算出最新的值
  307. now := time.Now()
  308. // 批量更新到分析表中,
  309. var updateAnalysisData []data_manage.UpdateDealValueChange
  310. for _, v := range changeList {
  311. str := v.ClassifyName + "_" + v.ClassifyType + "_" + v.DealShortName
  312. dealValue := 0
  313. dealChange := 0
  314. if v.DealType == 1 {
  315. if n, ok := originBuyMap[str]; ok {
  316. dealValue = n.DealValue - n.DealChange
  317. if beforeVal, ok1 := beforeYesterdayMap1[str]; ok1 {
  318. dealChange = dealValue - beforeVal
  319. }
  320. tmp := data_manage.UpdateDealValueChange{
  321. Id: v.Id,
  322. DealValue: dealValue,
  323. DealChange: dealChange,
  324. SourceType: 1,
  325. ModifyTime: now,
  326. }
  327. updateAnalysisData = append(updateAnalysisData, tmp)
  328. }
  329. } else if v.DealType == 2 {
  330. if n, ok := originSoldMap[str]; ok {
  331. dealValue = n.DealValue - n.DealChange
  332. if beforeVal, ok1 := beforeYesterdayMap2[str]; ok1 {
  333. dealChange = dealValue - beforeVal
  334. }
  335. tmp := data_manage.UpdateDealValueChange{
  336. Id: v.Id,
  337. DealValue: dealValue,
  338. DealChange: dealChange,
  339. SourceType: 1,
  340. ModifyTime: now,
  341. }
  342. updateAnalysisData = append(updateAnalysisData, tmp)
  343. }
  344. }
  345. }
  346. if len(updateAnalysisData) > 0 {
  347. err = data_manage.MultiUpdatePositionTop(exchange, updateAnalysisData)
  348. if err != nil {
  349. return
  350. }
  351. //删除T-1日净多单和净空单的榜单
  352. err = data_manage.DeletePositionTopByDataTime(exchange, yesterdayStr, 3)
  353. if err != nil {
  354. return
  355. }
  356. err = data_manage.DeletePositionTopByDataTime(exchange, yesterdayStr, 4)
  357. if err != nil {
  358. return
  359. }
  360. //重新生成净多单和净空单的榜单
  361. err = createAnalysisCleanTop(exchange, yesterdayStr, yesterdayStr)
  362. if err != nil {
  363. return
  364. }
  365. }
  366. return
  367. }
  368. // createAnalysisCleanTop 生成净多单,净空单榜单
  369. func createAnalysisCleanTop(exchange, startDate, endDate string) (err error) {
  370. defer func() {
  371. if err != nil {
  372. fmt.Println("createAnalysisCleanTop err: " + err.Error())
  373. }
  374. }()
  375. topList := make([]*data_manage.TradePositionTop, 0)
  376. now := time.Now()
  377. var subDataList data_manage.TradePositionSubList
  378. subChangeMap1 := make(map[string]int) //净多单map
  379. subChangeMap2 := make(map[string]int) //净空单map
  380. // 2023-05-10 此处取前一个交易日, 不一定是昨日
  381. dates, e := data_manage.GetTradePositionTopOriginDataTimes(exchange)
  382. if e != nil {
  383. err = fmt.Errorf("GetTradePositionTopOriginDataTimes err: %s", e.Error())
  384. return
  385. }
  386. yesterday := getPrevTradeDataDate(startDate, dates)
  387. //查询所有差值数据,
  388. //yesterday, err := getYesterdayDate(startDate)
  389. //if err != nil {
  390. // return
  391. //}
  392. // 上一个交易日的净多单
  393. yesterdayTopList1, tErr := data_manage.GetTradePositionTopByExchangeDataTimeType(exchange, yesterday, 3)
  394. if tErr != nil {
  395. err = tErr
  396. return
  397. }
  398. if len(yesterdayTopList1) > 0 {
  399. for _, v := range yesterdayTopList1 {
  400. nameStr := v.ClassifyName + "_" + v.ClassifyType + "_" + v.DataTime + "_" + v.DealShortName
  401. subChangeMap1[nameStr] = v.DealValue
  402. }
  403. }
  404. // 上一个交易日的净空单
  405. yesterdayTopList2, tErr := data_manage.GetTradePositionTopByExchangeDataTimeType(exchange, yesterday, 4)
  406. if tErr != nil {
  407. err = tErr
  408. return
  409. }
  410. if len(yesterdayTopList2) > 0 {
  411. for _, v := range yesterdayTopList2 {
  412. nameStr := v.ClassifyName + "_" + v.ClassifyType + "_" + v.DataTime + "_" + v.DealShortName
  413. subChangeMap2[nameStr] = v.DealValue
  414. }
  415. }
  416. // 根据当日多单/空单数据, 生成净多单/净空单数据
  417. originDataList, err := data_manage.GetTradePositionTopByExchangeDataTime(exchange, startDate, endDate)
  418. if err != nil {
  419. return
  420. }
  421. buyDataMap := make(map[string]int)
  422. for _, v := range originDataList {
  423. str := v.ClassifyName + "_" + v.ClassifyType + "_" + v.DataTime + "_" + v.DealShortName
  424. if v.DealType == 1 {
  425. buyDataMap[str] = v.DealValue
  426. } else if v.DealType == 2 {
  427. subValue := 0
  428. dealType := 0
  429. if buy, ok := buyDataMap[str]; ok {
  430. subValue = buy - v.DealValue
  431. if subValue >= 0 {
  432. dealType = 3
  433. } else {
  434. subValue = -subValue
  435. dealType = 4
  436. }
  437. }
  438. tmp := &data_manage.TradePositionSub{
  439. ClassifyName: v.ClassifyName,
  440. ClassifyType: v.ClassifyType,
  441. DataTime: v.DataTime,
  442. DealShortName: v.DealShortName,
  443. SubValue: subValue,
  444. DealType: dealType,
  445. }
  446. subDataList = append(subDataList, tmp)
  447. }
  448. }
  449. if len(subDataList) > 0 {
  450. sort.Sort(subDataList)
  451. }
  452. // 根据净多单/净空单数据, 比对上一个交易日的日期计算成交变化量, 并写入
  453. var dealType int
  454. rankMap := make(map[string]int)
  455. for _, v := range subDataList {
  456. subValue := v.SubValue
  457. nameStr := v.ClassifyName + "_" + v.ClassifyType + "_" + v.DataTime + "_" + v.DealShortName
  458. if v.DealType == 3 {
  459. subChangeMap1[nameStr] = subValue
  460. dealType = 3
  461. if _, ok := rankMap[v.ClassifyName+"_"+v.ClassifyType+"_"+v.DataTime+"_3"]; !ok {
  462. rankMap[v.ClassifyName+"_"+v.ClassifyType+"_"+v.DataTime+"_3"] = 1
  463. } else {
  464. rankMap[v.ClassifyName+"_"+v.ClassifyType+"_"+v.DataTime+"_3"]++
  465. }
  466. } else if v.DealType == 4 {
  467. subChangeMap2[nameStr] = subValue
  468. dealType = 4
  469. if _, ok := rankMap[v.ClassifyName+"_"+v.ClassifyType+"_"+v.DataTime+"_4"]; !ok {
  470. rankMap[v.ClassifyName+"_"+v.ClassifyType+"_"+v.DataTime+"_4"] = 1
  471. } else {
  472. rankMap[v.ClassifyName+"_"+v.ClassifyType+"_"+v.DataTime+"_4"]++
  473. }
  474. }
  475. // 2023-05-10 目前看该方法的引用startDate和endDate其实是同一天, 所以前一个交易日直接用上面的yesterday
  476. tmpTimeStr := yesterday
  477. //和T-1日比较差值
  478. //var tmpTimeStr string
  479. //tmpTimeStr, err = getYesterdayDate(v.DataTime)
  480. //if err != nil {
  481. // return
  482. //}
  483. yesterdayStr := v.ClassifyName + "_" + v.ClassifyType + "_" + tmpTimeStr + "_" + v.DealShortName
  484. dealChange := 0
  485. if dealType == 3 {
  486. if c, ok := subChangeMap1[yesterdayStr]; ok {
  487. dealChange = subValue - c
  488. }
  489. } else if dealType == 4 {
  490. if c, ok := subChangeMap2[yesterdayStr]; ok {
  491. dealChange = subValue - c
  492. }
  493. }
  494. tmp := &data_manage.TradePositionTop{
  495. ClassifyName: v.ClassifyName,
  496. ClassifyType: v.ClassifyType,
  497. DataTime: v.DataTime,
  498. CreateTime: now,
  499. ModifyTime: now,
  500. DealShortName: v.DealShortName,
  501. DealValue: subValue,
  502. DealChange: dealChange,
  503. DealType: dealType,
  504. Rank: rankMap[v.ClassifyName+"_"+v.ClassifyType+"_"+v.DataTime+"_"+strconv.Itoa(dealType)],
  505. }
  506. topList = append(topList, tmp)
  507. if len(topList) >= 1000 {
  508. err = data_manage.InsertMultiTradePositionTop(exchange, topList)
  509. if err != nil {
  510. return
  511. }
  512. topList = make([]*data_manage.TradePositionTop, 0)
  513. }
  514. }
  515. if len(topList) >= 0 {
  516. err = data_manage.InsertMultiTradePositionTop(exchange, topList)
  517. if err != nil {
  518. return
  519. }
  520. }
  521. return
  522. }
  523. func getYesterdayDate(today string) (yesterday string, err error) {
  524. i := 1
  525. tmpTime, err := time.ParseInLocation(utils.FormatDate, today, time.Local)
  526. if err != nil {
  527. return
  528. }
  529. tmpTimeDate := tmpTime.AddDate(0, 0, -i)
  530. weekStr := tmpTimeDate.Weekday().String()
  531. if weekStr == "Sunday" {
  532. i += 2
  533. } else if weekStr == "Saturday" {
  534. i += 1
  535. }
  536. tmpTimeDate = tmpTime.AddDate(0, 0, -i)
  537. yesterday = tmpTimeDate.Format(utils.FormatDate)
  538. return
  539. }
  540. // getPrevTradeDataDate 获取指定日期上一个交易日日期
  541. func getPrevTradeDataDate(date string, dates []string) string {
  542. pre := -1
  543. for k, v := range dates {
  544. n := k - 1
  545. if v == date && n >= 0 {
  546. pre = n
  547. break
  548. }
  549. }
  550. // 找不到就随便给个不存在日期
  551. if pre == -1 {
  552. return "1980-01-01"
  553. }
  554. return dates[pre]
  555. }