From e2b338a4cd4174f6cff839773ac2a8b7511bfa80 Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Fri, 10 Oct 2025 19:13:27 +0800
Subject: [PATCH] 1
---
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java | 138 +++++++++++++++++++++++++++++++++++++++++++--
1 files changed, 130 insertions(+), 8 deletions(-)
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java
index fb05daa..7b6966d 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java
@@ -7,6 +7,7 @@
import com.yami.trading.common.config.RequestDataHelper;
import com.yami.trading.common.constants.Constants;
import com.yami.trading.common.util.DateUtils;
+import com.yami.trading.huobi.data.AdjustmentValueCache;
import com.yami.trading.huobi.data.DataCache;
import com.yami.trading.huobi.hobi.HobiDataService;
import com.yami.trading.service.data.KlineDBService;
@@ -18,6 +19,7 @@
import org.springframework.jdbc.core.namedparam.NamedParameterJdbcOperations;
import org.springframework.stereotype.Component;
+import java.math.BigDecimal;
import java.util.*;
@Component
@@ -34,6 +36,38 @@
private SysparaService sysparaService;
@Autowired
private NamedParameterJdbcOperations namedParameterJdbcTemplate;
+
+ public static void main(String[] args) {
+ BigDecimal a = BigDecimal.valueOf(0.0007);
+ BigDecimal b = BigDecimal.valueOf(333);
+ BigDecimal c = a.divide(b, 6, BigDecimal.ROUND_HALF_UP);
+ System.out.println(c);
+ }
+ @Override
+ public void initBySql(String symbol) {
+ this.bulidBySql(symbol, Kline.PERIOD_1MIN);
+ this.bulidBySql(symbol, Kline.PERIOD_5MIN);
+ this.bulidBySql(symbol, Kline.PERIOD_15MIN);
+ this.bulidBySql(symbol, Kline.PERIOD_30MIN);
+ this.bulidBySql(symbol, Kline.PERIOD_60MIN);
+ this.bulidBySql(symbol, Kline.PERIOD_4HOUR);
+ this.bulidBySql(symbol, Kline.PERIOD_1DAY);
+ this.bulidBySql(symbol, Kline.PERIOD_1MON);
+ this.bulidBySql(symbol, Kline.PERIOD_1WEEK);
+ }
+
+ @Override
+ public void init(String symbol) {
+ this.bulid(symbol, Kline.PERIOD_1MIN);
+ this.bulid(symbol, Kline.PERIOD_5MIN);
+ this.bulid(symbol, Kline.PERIOD_15MIN);
+ this.bulid(symbol, Kline.PERIOD_30MIN);
+ this.bulid(symbol, Kline.PERIOD_60MIN);
+ this.bulid(symbol, Kline.PERIOD_4HOUR);
+ this.bulid(symbol, Kline.PERIOD_1DAY);
+ this.bulid(symbol, Kline.PERIOD_1MON);
+ this.bulid(symbol, Kline.PERIOD_1WEEK);
+ }
@Override
public void saveInit(String symbol) {
@@ -55,6 +89,36 @@
}
+ public void bulidBySql(String symbol, String line) {
+ RequestDataHelper.set("symbol", symbol);
+ LambdaQueryWrapper<Kline> queryWrapper = new LambdaQueryWrapper<Kline>()
+ .eq(Kline::getSymbol, symbol)
+ .eq(Kline::getPeriod, line)
+ .orderByAsc(Kline::getTs);
+ List<Kline> list = klineDBService.list(queryWrapper);
+
+ KlineTimeObject model = new KlineTimeObject();
+ Collections.sort(list); // 按时间升序
+ model.setKline(list);
+ model.setLastTime(new Date());
+ DataCache.putKline(symbol, line, model);
+ RequestDataHelper.clear();
+
+ }
+
+ public void bulid(String symbol, String line) {
+ RequestDataHelper.set("symbol", symbol);
+ List<Kline> list = hobiDataService.kline(itemService.findBySymbol(symbol).getSymbol(), line, null,
+ 0);
+ KlineTimeObject model = new KlineTimeObject();
+ Collections.sort(list); // 按时间升序
+ model.setKline(list);
+ model.setLastTime(new Date());
+ DataCache.putKline(symbol, line, model);
+ RequestDataHelper.clear();
+
+ }
+
public void bulidInit(String symbol, String line) {
RequestDataHelper.set("symbol", symbol);
List<Kline> list = hobiDataService.kline(itemService.findBySymbol(symbol).getSymbol(), line, null,
@@ -69,9 +133,12 @@
}
+
+
@Override
public void saveOne(String symbol, String line) {
- RequestDataHelper.set("symbol", symbol);
+ saveOneByHuoBi(symbol, line);
+ /*RequestDataHelper.set("symbol", symbol);
Realtime realtime = DataCache.getRealtime(symbol);
if (realtime == null) {
logger.error("saveOne error, realtime is null,symbol [" + symbol + "]");
@@ -87,12 +154,13 @@
String key = symbol + "_" + line;
Kline hobiOne = DataCache.getKline_hobi().get(key);
- if (hobiOne == null || lastOne == null) {
+ *//*if (hobiOne == null || lastOne == null) {
+ logger.error("saveOne error, hobiOne is null,symbol [" + symbol + "]");
// 取不到远程数据,直接退出
return;
- }
+ }*//*
RequestDataHelper.set("symbol", symbol);
- Kline kline = this.bulidKline(realtime, lastOne, hobiOne, line);
+ Kline kline = this.bulidKline(realtime, lastOne, null, line);
kline.setPeriod(line);
klineDBService.save(kline);
@@ -105,8 +173,52 @@
timeObject.getKline().add(kline);
timeObject.setLastTime(new Date());
DataCache.putKline(symbol, line, timeObject);
- RequestDataHelper.clear();
+ RequestDataHelper.clear();*/
+ }
+
+ @Override
+ public void saveOneByHuoBi(String symbol, String line) {
+ RequestDataHelper.set("symbol", symbol);
+ List<Kline> list = hobiDataService.kline(itemService.findBySymbol(symbol).getSymbol(), line, 2,
+ 0);
+ if (list == null || list.isEmpty()) {
+ return;
+ }
+ Kline kline = list.get(0);
+ BigDecimal currentValue = AdjustmentValueCache.getCurrentValue().get(symbol);
+ if (currentValue != null && currentValue.compareTo(BigDecimal.ZERO) > 0) {
+ if (!kline.isAdjusted()){
+ kline.setClose(kline.getClose().add(currentValue));
+ kline.setOpen(kline.getOpen().add(currentValue));
+ kline.setLow(kline.getLow().add(currentValue));
+ kline.setHigh(kline.getHigh().add(currentValue));
+ kline.setAdjusted(true);
+
+ /*BigDecimal last = AdjustmentValueCache.getLastValue().get(symbol);
+ if (last != null && last.compareTo(BigDecimal.ZERO) > 0) {
+ BigDecimal adj = currentValue.subtract(last);
+ if (adj.compareTo(BigDecimal.ZERO) > 0) { //递增
+ kline.setOpen(kline.getOpen().subtract(adj));
+ kline.setLow(kline.getLow().subtract(adj));
+ } else if(adj.compareTo(BigDecimal.ZERO) < 0){ //递减
+ kline.setOpen(kline.getOpen().subtract(adj));
+ kline.setHigh(kline.getHigh().subtract(adj));
+ }
+ } else {
+ AdjustmentValueCache.getLastValue().put(symbol, currentValue);
+ }*/
+ }
+ }
+ klineDBService.save(kline);
+ KlineTimeObject timeObject = DataCache.getKline(symbol, line);
+ if (timeObject == null) {
+ timeObject = new KlineTimeObject();
+ }
+ timeObject.getKline().add(kline);
+ timeObject.setLastTime(new Date());
+ DataCache.putKline(symbol, line, timeObject);
+ RequestDataHelper.clear();
}
public Kline bulidKline(Realtime realtime, Kline lastOne, Kline hobiOne, String line) {
@@ -124,8 +236,17 @@
if (lastOne != null) {
kline.setOpen(lastOne.getClose());
+ kline.setHigh(lastOne.getClose());
+ kline.setLow(lastOne.getClose());
+
+ if (realtime.getClose().compareTo(kline.getHigh()) > 0) {
+ kline.setHigh(realtime.getClose());
+ }
+ if (realtime.getClose().compareTo(kline.getLow()) < 0) {
+ kline.setLow(realtime.getClose());
+ }
}
- int interval = this.sysparaService.find("data_interval").getInteger().intValue() / 1000;
+ /*int interval = this.sysparaService.find("data_interval").getInteger().intValue() / 1000;
HighLow highLow = null;
switch (line) {
@@ -169,9 +290,10 @@
}
if (highLow != null && highLow.getLow() != null) {
kline.setLow(highLow.getLow());
- }
+ }*/
- kline.setVolume(hobiOne.getVolume());
+
+ //kline.setVolume(hobiOne.getVolume());
return kline;
}
--
Gitblit v1.9.3