From 6ca466185554ac1671af9556d4b2f9df9c8c9974 Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Wed, 14 Jan 2026 16:09:41 +0800
Subject: [PATCH] 1

---
 src/main/java/com/nq/service/impl/StockServiceImpl.java |   29 +++++++++++++++--------------
 1 files changed, 15 insertions(+), 14 deletions(-)

diff --git a/src/main/java/com/nq/service/impl/StockServiceImpl.java b/src/main/java/com/nq/service/impl/StockServiceImpl.java
index dae6211..bf35ca2 100644
--- a/src/main/java/com/nq/service/impl/StockServiceImpl.java
+++ b/src/main/java/com/nq/service/impl/StockServiceImpl.java
@@ -931,30 +931,31 @@
                         continue; // 股票不存在,跳过
                     }
                     
-                    // 先获取真实价格(从Redis获取,不经过StockSetting计算)
-                    String s = RedisKeyUtil.doPost(stock.getStockCode(), stock.getStockType());
-                    if (s == null) {
-                        continue; // 无法获取真实价格,跳过
+                    // 先获取真实数据,用于获取前收盘价和当前价格
+                    StockRealTimeBean realTimeStock = RedisKeyUtil.getCacheRealTimeStock(stock);
+                    if (realTimeStock == null || realTimeStock.getPc() == null) {
+                        continue; // 无法获取真实数据,跳过
                     }
                     
-                    Map<String, Object> stringObjectMap = RedisKeyUtil.jsonToMap(s);
-                    BigDecimal realPrice = new BigDecimal(stringObjectMap.get("Last").toString());
+                    // 获取前收盘价和当前价格(last)
+                    BigDecimal prevClose = new BigDecimal(realTimeStock.getPc());
+                    BigDecimal last = new BigDecimal(realTimeStock.getLast());
                     
-                    // 计算盘前价格
+                    // 计算盘前价格(根据StockSetting配置)
                     BigDecimal premarketPrice;
                     if ("0".equals(setting.getType())) {
                         // type=0: 直接指定价格
                         premarketPrice = new BigDecimal(setting.getPrice());
                     } else {
-                        // type=1: 百分比调价格,基于真实价格计算
-                        premarketPrice = realPrice.multiply(new BigDecimal(setting.getPrice()));
+                        // type=1: 百分比调价格,基于last计算
+                        premarketPrice = last.multiply(new BigDecimal(setting.getPrice()));
                     }
                     
-                    // 计算涨跌幅 = (盘前价格 - 真实价格) / 真实价格
+                    // 根据盘前价格计算涨跌幅 = (盘前价格 - 前收盘价) / 前收盘价
                     BigDecimal hcrate = BigDecimal.ZERO;
-                    if (realPrice.compareTo(BigDecimal.ZERO) > 0) {
-                        hcrate = premarketPrice.subtract(realPrice)
-                                .divide(realPrice, 4, RoundingMode.HALF_UP);
+                    if (prevClose.compareTo(BigDecimal.ZERO) > 0) {
+                        hcrate = premarketPrice.subtract(prevClose)
+                                .divide(prevClose, 4, RoundingMode.HALF_UP);
                     }
                     
                     // 格式化涨跌幅为带百分号的字符串
@@ -963,7 +964,7 @@
                     
                     PremarketStockVO vo = new PremarketStockVO();
                     vo.setCode(setting.getStockCode());
-                    vo.setPrice(premarketPrice);
+                    vo.setPrice(premarketPrice); // price返回盘前价格
                     vo.setHcrate(hcrate);
                     vo.setHcrateP(hcrateP);
                     resultList.add(vo);

--
Gitblit v1.9.3