From cf4df50c71235bfa6ee73776c556ee1f95ce6356 Mon Sep 17 00:00:00 2001
From: Administrator <admin@example.com>
Date: 星期一, 15 七月 2024 16:59:55 +0800
Subject: [PATCH] 独苗定义强化

---
 code_attribute/first_target_code_data_processor.py |   20 +++++++++++++++-----
 1 files changed, 15 insertions(+), 5 deletions(-)

diff --git a/code_attribute/first_target_code_data_processor.py b/code_attribute/first_target_code_data_processor.py
index 01da882..eaff5e7 100644
--- a/code_attribute/first_target_code_data_processor.py
+++ b/code_attribute/first_target_code_data_processor.py
@@ -12,6 +12,7 @@
 from code_attribute.gpcode_manager import WantBuyCodesManager
 from log_module.log import logger_first_code_record, logger_l2_codes_subscript
 from third_data.code_plate_key_manager import CodesHisReasonAndBlocksManager
+from third_data.history_k_data_manager import HistoryKDataManager
 from third_data.history_k_data_util import HistoryKDatasUtils, JueJinApi
 from ths import l2_code_operate
 from trade import trade_data_manager, l2_trade_util
@@ -41,9 +42,12 @@
 
 def process_first_codes_datas(dataList, request_id=None):
     logger_l2_codes_subscript.info(f"{request_id}鍔犺浇l2浠g爜鐩稿叧鏁版嵁")
-    print("棣栨澘浠g爜鏁伴噺锛�", len(dataList))
     # 鑾峰彇鏈�杩�5澶╃殑浜ゆ槗鏃ユ湡锛屼负鍚庨潰鐨勬暟鎹绠楀仛鍑嗗
-    HistoryKDatasUtils.get_latest_trading_date_cache(5)
+    dates = HistoryKDatasUtils.get_latest_trading_date_cache(5)
+    latest_trading_date = None
+    if dates:
+        latest_trading_date = dates[0]
+
     limit_up_price_dict = {}
     temp_codes = []
     codes = []
@@ -96,7 +100,12 @@
             if limit_up_price is None:
                 continue
             try:
-                volumes_data = init_data_util.get_volumns_by_code(code, 150)
+                # 棣栧厛浠庣紦瀛橀噷闈㈣幏鍙�
+                volumes_data = None
+                if latest_trading_date:
+                    volumes_data = HistoryKDataManager().get_history_bars(code, latest_trading_date)
+                if not volumes_data:
+                    volumes_data = init_data_util.get_volumns_by_code(code, 150)
                 volumes = init_data_util.parse_max_volume(code, volumes_data[:90],
                                                           code_nature_analyse.is_new_top(code,
                                                                                          limit_up_price,
@@ -127,7 +136,8 @@
                             l2_trade_util.forbidden_trade(code,
                                                           f"鏃犺鲸璇嗗害锛屾定鍋滀环({limit_up_price})>50")
                             continue
-                    if code_nature_analyse.is_price_too_high_in_days(code, volumes_data, limit_up_price)[0] and code.find("30")!=0:
+                    if code_nature_analyse.is_price_too_high_in_days(code, volumes_data, limit_up_price)[
+                        0] and code.find("30") != 0:
                         # 鍒ゆ柇鏄惁澶珮
                         l2_trade_util.forbidden_trade(code, "6澶╁唴鑲′环闀垮緱澶珮")
                         continue
@@ -170,7 +180,7 @@
                 #                                      gpcode_manager.get_limit_up_price(code),
                 #                                      volumes_data)
             except Exception as e:
-                logger_first_code_record.error(f"{code}:{str(e)}")
+                logger_first_code_record.error(f"{request_id}-{code}:{str(e)}")
                 logger_first_code_record.exception(e)
 
     logger_l2_codes_subscript.info(f"{request_id}鍔犺浇l2浠g爜K绾跨粨鏉�")

--
Gitblit v1.8.0