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 |   36 +++++++++++++++++++++++++++++-------
 1 files changed, 29 insertions(+), 7 deletions(-)

diff --git a/code_attribute/first_target_code_data_processor.py b/code_attribute/first_target_code_data_processor.py
index b7db9e6..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
@@ -103,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:
@@ -127,9 +129,32 @@
                 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):
@@ -138,10 +163,7 @@
                     # 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澶╂槸鍚︽槸鏈�楂橀噺
@@ -162,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:
@@ -231,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