From 6cb024949e4ffd47bef3a254fb256e331731e5bb Mon Sep 17 00:00:00 2001
From: Administrator <admin@example.com>
Date: 星期五, 12 一月 2024 18:10:11 +0800
Subject: [PATCH] 重新应用想买单

---
 code_attribute/first_target_code_data_processor.py |   45 ++++++++++++++++++++++++++++++++++++---------
 1 files changed, 36 insertions(+), 9 deletions(-)

diff --git a/code_attribute/first_target_code_data_processor.py b/code_attribute/first_target_code_data_processor.py
index 90e88ee..81981df 100644
--- a/code_attribute/first_target_code_data_processor.py
+++ b/code_attribute/first_target_code_data_processor.py
@@ -9,6 +9,7 @@
     code_volumn_manager
 from code_attribute.code_data_util import ZYLTGBUtil
 from code_attribute.code_nature_analyse import HighIncreaseCodeManager
+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_util import HistoryKDatasUtils
@@ -22,6 +23,8 @@
 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)
     limit_up_price_dict = {}
     temp_codes = []
     codes = []
@@ -101,7 +104,8 @@
     # 鑾峰彇60澶╂渶澶ц褰�
     for code in codes:
         need_get_volumn = False
-        if code not in global_util.max60_volumn or global_util.max60_volumn.get(code) is None:
+        if code not in global_util.max60_volumn or global_util.max60_volumn.get(
+                code) is None or code_nature_analyse.CodeNatureRecordManager().get_k_format_cache(code) is None:
             need_get_volumn = True
         # if not need_get_volumn and code_nature_analyse.CodeNatureRecordManager.get_nature_cache(
         #         code) is None:
@@ -115,6 +119,8 @@
                 volumes = init_data_util.parse_max_volume(volumes_data[:90],
                                                           code_nature_analyse.is_new_top(
                                                               limit_up_price,
+                                                              volumes_data[:90]) or code_nature_analyse.is_near_top(
+                                                              limit_up_price,
                                                               volumes_data[:90]))
                 logger_first_code_record.info("{} 鑾峰彇鍒伴鏉�60澶╂渶澶ч噺锛歿}", code, volumes)
                 code_volumn_manager.set_histry_volumn(code, volumes[0], volumes[1], volumes[2])
@@ -123,20 +129,41 @@
                 k_format = code_nature_analyse.get_k_format(limit_up_price, volumes_data)
                 code_nature_analyse.CodeNatureRecordManager().save_k_format(code, k_format)
 
+                # 鏄惁鍏锋湁杈ㄨ瘑搴�
+                is_special = True if k_format and k_format[8][0] else False
+                if not WantBuyCodesManager().is_in_cache(code):
+                    if not is_special:
+                        if global_util.zyltgb_map.get(code) and global_util.zyltgb_map.get(code) > 31 * 100000000:
+                            l2_trade_util.forbidden_trade(code,
+                                                          f"鏃犺鲸璇嗗害锛岃嚜鐢辨祦閫氬競鍊�({global_util.zyltgb_map.get(code) // 100000000})>31浜�")
+                            continue
+                        elif limit_up_price and float(limit_up_price) >= 50:
+                            l2_trade_util.forbidden_trade(code,
+                                                          f"鏃犺鲸璇嗗害锛屾定鍋滀环({limit_up_price})>50")
+                            continue
+                    if code_nature_analyse.is_price_too_high_in_days(volumes_data, limit_up_price):
+                        # 鍒ゆ柇鏄惁澶珮
+                        l2_trade_util.forbidden_trade(code, "6澶╁唴鑲′环闀垮緱澶珮")
+                        continue
+
+                    if code_nature_analyse.is_continue_limit_up_not_enough_fall_dwon(volumes_data):
+                        # 鍒ゆ柇鏄惁澶珮
+                        l2_trade_util.forbidden_trade(code, "鍥炶俯涓嶅")
+                        continue
+
+
+
                 if code_nature_analyse.is_up_too_high_in_10d_with_limit_up(volumes_data):
                     # 鍒ゆ柇鏄惁澶珮
-                    # l2_trade_util.forbidden_trade(code, "鑲′环闀垮緱澶珮锛�5澶╁唴鏈�3涓定鍋滐級")
                     HighIncreaseCodeManager().add_code(code)
 
                 if code_nature_analyse.is_up_too_high_in_120d(volumes_data):
                     # 鍒ゆ柇鏄惁澶珮
-                    l2_trade_util.forbidden_trade(code, "120澶╁唴鑲′环闀垮緱澶珮")
-                    HighIncreaseCodeManager().add_code(code)
+                    # l2_trade_util.forbidden_trade(code, "120澶╁唴鑲′环闀垮緱澶珮")
+                    # HighIncreaseCodeManager().add_code(code)
+                    pass
 
-                if code_nature_analyse.is_price_too_high_in_days(volumes_data, limit_up_price):
-                    # 鍒ゆ柇鏄惁澶珮
-                    l2_trade_util.forbidden_trade(code, "6澶╁唴鑲′环闀垮緱澶珮")
-                    HighIncreaseCodeManager().add_code(code)
+
 
                 if code_nature_analyse.is_have_latest_max_volume(volumes_data, 2):
                     # 鏈�杩�2澶╂槸鍚︽槸鏈�楂橀噺
@@ -157,6 +184,7 @@
                 #                                      volumes_data)
             except Exception as e:
                 logger_first_code_record.error(f"{code}:{str(e)}")
+                logger_first_code_record.exception(e)
     gpcode_manager.FirstCodeManager().add_record(codes)
     # 鍒濆鍖栨澘鍧椾俊鎭紝鏆傛椂鍒犻櫎
     # for code in codes:
@@ -226,4 +254,3 @@
     gpcode_first_screen_manager.process_ticks(prices)
     logger_l2_codes_subscript.info(f"({request_id})l2浠g爜鐩稿叧鏁版嵁鍔犺浇瀹屾垚")
     return tick_datas
-

--
Gitblit v1.8.0