From 45e55401d2298a9689295b75d544cc5fa2cef787 Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Fri, 10 Oct 2025 12:08:46 +0800
Subject: [PATCH] 调整值优化
---
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java | 16 +++++++++++++++-
1 files changed, 15 insertions(+), 1 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 3bcb03f..7821323 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
@@ -174,7 +174,7 @@
@Override
public void saveOneByHuoBi(String symbol, String line) {
RequestDataHelper.set("symbol", symbol);
- List<Kline> list = hobiDataService.kline(itemService.findBySymbol(symbol).getSymbol(), line, 1,
+ List<Kline> list = hobiDataService.kline(itemService.findBySymbol(symbol).getSymbol(), line, 2,
0);
if (list == null || list.isEmpty()) {
return;
@@ -188,6 +188,20 @@
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);
--
Gitblit v1.9.3