From 3da5d1ef00cf7665c2d37f837e6845c92d22e31c Mon Sep 17 00:00:00 2001
From: Administrator <admin@example.com>
Date: 星期五, 15 十二月 2023 16:02:08 +0800
Subject: [PATCH] 前日炸板策略修改

---
 l2/l2_transaction_data_manager.py |   31 ++++++++++++++++++++-----------
 1 files changed, 20 insertions(+), 11 deletions(-)

diff --git a/l2/l2_transaction_data_manager.py b/l2/l2_transaction_data_manager.py
index c774f9f..c06e3d8 100644
--- a/l2/l2_transaction_data_manager.py
+++ b/l2/l2_transaction_data_manager.py
@@ -10,11 +10,13 @@
 from db.redis_manager_delegate import RedisUtils
 from l2 import l2_data_util, l2_data_manager, transaction_progress
 from l2.cancel_buy_strategy import LCancelRateManager, LCancelBigNumComputer, \
-    SecondCancelBigNumComputer, HourCancelBigNumComputer, FastCancelBigNumComputer
+    SecondCancelBigNumComputer, HourCancelBigNumComputer, FastCancelBigNumComputer, UCancelBigNumComputer
+from l2.l2_data_manager_new import L2TradeDataProcessor
 from l2.l2_data_util import L2DataUtil
 from log_module import async_log_util
 from log_module.log import logger_l2_trade_buy_queue, hx_logger_l2_upload, hx_logger_l2_debug, \
-    hx_logger_l2_transaction_desc
+    hx_logger_l2_transaction_desc, logger_debug
+from third_data import kpl_data_manager
 from trade import current_price_process_manager, trade_manager, l2_trade_factor
 from trade.deal_big_money_manager import DealOrderNoManager
 from utils import tool
@@ -126,18 +128,11 @@
                     val = data["val"]
                     if l2_data_util.is_big_money(val) and L2DataUtil.is_limit_up_price_buy(val):
                         big_money_count += 1
-                        DealOrderNoManager().add_orderno(code, deal_info[0])
+                        DealOrderNoManager().add_orderno(code, f"{deal_info[0]}")
                     # L鍚庢槸鍚︽湁鎴愪氦锛屽鏋滄湁鎴愪氦灏遍渶瑕侀櫎鍘诲綋鍓嶇瑪鏁帮紝鐒跺悗閲嶆柊鍥婃嫭涓�绗�
                     LCancelBigNumComputer().add_deal_index(code, data["index"], order_begin_pos.buy_single_index)
             if big_money_count > 0:
-                # 缁熻澶у崟/m鍊兼垚浜ゆ瘮
-                total_deal_nums = DealOrderNoManager().get_deal_nums(code, buyno_map)
-                thresh_hold_money = l2_trade_factor.L2PlaceOrderParamsManager.get_base_m_val(code)
-                limit_up_price = gpcode_manager.get_limit_up_price(code)
-                if limit_up_price:
-                    rate = round(total_deal_nums / (thresh_hold_money // (float(limit_up_price) * 100)), 2)
-                    LCancelRateManager().set_big_num_deal_rate(code, rate)
-                    # 鑾峰彇鎵ц浣嶆椂闂�
+                LCancelRateManager.compute_big_num_deal_rate(code)
 
             buy_progress_index = self.__compute_latest_trade_progress(code, buyno_map, datas)
             if buy_progress_index is not None:
@@ -155,6 +150,20 @@
                 if order_begin_pos and order_begin_pos.buy_exec_index and order_begin_pos.buy_exec_index > -1:
                     HourCancelBigNumComputer().set_transaction_index(code, order_begin_pos.buy_single_index,
                                                                      buy_progress_index)
+                    # ---------------------------------鍒ゆ柇鏉垮潡鏄惁璺熶笂鏉ヤ簡-------------------------------
+                    try:
+                        order_begin_pos = l2_data_manager.TradePointManager().get_buy_compute_start_data_cache(code)
+                        volume_rate = 0
+                        volume_info = L2TradeDataProcessor.volume_rate_info.get(code)
+                        if volume_info:
+                            volume_rate = volume_info[0]
+                        need_cancel, msg = UCancelBigNumComputer().need_cancel(code, buy_progress_index, order_begin_pos,
+                                                                               kpl_data_manager.KPLLimitUpDataRecordManager.get_current_reason_codes_dict(),
+                                                                               volume_rate)
+                        if need_cancel:
+                            L2TradeDataProcessor.cancel_buy(code, msg)
+                    except Exception as e:
+                        logger_debug.exception(e)
             else:
                 pass
             if order_begin_pos and order_begin_pos.buy_exec_index and order_begin_pos.buy_exec_index > -1:

--
Gitblit v1.8.0