From bb2e450c9d0e9d42929ecd6030a1fb65b2034176 Mon Sep 17 00:00:00 2001
From: Administrator <admin@example.com>
Date: 星期五, 24 一月 2025 14:33:55 +0800
Subject: [PATCH] bug修复

---
 code_attribute/first_target_code_data_processor.py |   48 ++++++++++++++++++++++--------------------------
 1 files changed, 22 insertions(+), 26 deletions(-)

diff --git a/code_attribute/first_target_code_data_processor.py b/code_attribute/first_target_code_data_processor.py
index 98f4b5a..ac34fd9 100644
--- a/code_attribute/first_target_code_data_processor.py
+++ b/code_attribute/first_target_code_data_processor.py
@@ -42,7 +42,7 @@
 
 
 def process_first_codes_datas(dataList, request_id=None):
-    logger_l2_codes_subscript.info(f"{request_id}鍔犺浇l2浠g爜鐩稿叧鏁版嵁")
+    async_log_util.info(logger_l2_codes_subscript, f"{request_id}鍔犺浇l2浠g爜鐩稿叧鏁版嵁")
     # 鑾峰彇鏈�杩�5澶╃殑浜ゆ槗鏃ユ湡锛屼负鍚庨潰鐨勬暟鎹绠楀仛鍑嗗
     dates = HistoryKDatasUtils.get_latest_trading_date_cache(5)
     latest_trading_date = None
@@ -110,18 +110,12 @@
                     async_log_util.info(logger_l2_codes_subscript, f"{request_id}浠庣綉缁滃姞杞終绾挎暟鎹細{code}")
                 if not volumes_data:
                     continue
-                volumes = init_data_util.parse_max_volume(code, volumes_data[:90],
-                                                          code_nature_analyse.is_new_top(code,
-                                                                                         limit_up_price,
-                                                                                         volumes_data[
-                                                                                         :90]) or code_nature_analyse.is_near_top(
-                                                              code,
-                                                              limit_up_price,
-                                                              volumes_data[:90]))
+                volumes = init_data_util.parse_max_volume_new(code, volumes_data[:60])
                 max_volume_in_5_days = init_data_util.parse_max_volume_in_days(volumes_data, 5)
 
                 async_log_util.info(logger_first_code_record, f"{code} 鑾峰彇鍒伴鏉�60澶╂渶澶ч噺锛歿volumes}")
-                code_volumn_manager.CodeVolumeManager().set_histry_volumn(code, volumes[0], volumes[1], volumes[2], volumes[3], max_volume_in_5_days)
+                code_volumn_manager.CodeVolumeManager().set_histry_volumn(code, volumes[0], volumes[1], volumes[2],
+                                                                          volumes[3], max_volume_in_5_days)
 
                 # 淇濆瓨K绾垮舰鎬�
                 k_format = code_nature_analyse.get_k_format(code, limit_up_price, volumes_data)
@@ -129,26 +123,28 @@
 
                 # 鏄惁鍏锋湁杈ㄨ瘑搴�
                 is_special = True if k_format and k_format[8][0] else False
-                if not WantBuyCodesManager().is_in_cache(code) and not gpcode_manager.BuyOpenLimitUpCodeManager().is_in_cache(code):
+                if not WantBuyCodesManager().is_in_cache(
+                        code) and not gpcode_manager.BuyOpenLimitUpCodeManager().is_in_cache(code):
                     # 涓嶆槸鎯充拱鍗曪紝涔熶笉鏄帓涓�鐨勪唬鐮�
-                    if not is_special:
-                        situation = MarketSituationManager().get_situation_cache()
-                        zylt_threshold_as_yi = buy_condition_util.get_zyltgb_threshold(situation)
-                        if global_util.zyltgb_map.get(code) and global_util.zyltgb_map.get(code) > zylt_threshold_as_yi[
-                            1] * 100000000:
-                            l2_trade_util.forbidden_trade(code,
-                                                          f"鏃犺鲸璇嗗害锛岃嚜鐢辨祦閫氬競鍊�({global_util.zyltgb_map.get(code) // 100000000})>{zylt_threshold_as_yi[1]}浜�")
-                            continue
-                        elif limit_up_price and float(limit_up_price) >= constant.MAX_CODE_PRICE:
-                            l2_trade_util.forbidden_trade(code,
-                                                          f"鏃犺鲸璇嗗害锛屾定鍋滀环({limit_up_price})>{constant.MAX_CODE_PRICE}")
-                            continue
-                    if code_nature_analyse.is_price_too_high_in_days(code, volumes_data, limit_up_price)[
-                        0] and code.find("30") != 0:
+                    # if not is_special:
+                    #     situation = MarketSituationManager().get_situation_cache()
+                    #     zylt_threshold_as_yi = buy_condition_util.get_zyltgb_threshold(situation)
+                    #     if global_util.zyltgb_map.get(code) and global_util.zyltgb_map.get(code) > zylt_threshold_as_yi[
+                    #         1] * 100000000:
+                    #         l2_trade_util.forbidden_trade(code,
+                    #                                       f"鏃犺鲸璇嗗害锛岃嚜鐢辨祦閫氬競鍊�({global_util.zyltgb_map.get(code) // 100000000})>{zylt_threshold_as_yi[1]}浜�")
+                    #         continue
+                    #     elif limit_up_price and float(limit_up_price) >= constant.MAX_CODE_PRICE:
+                    #         l2_trade_util.forbidden_trade(code,
+                    #                                       f"鏃犺鲸璇嗗害锛屾定鍋滀环({limit_up_price})>{constant.MAX_CODE_PRICE}")
+                    #         continue
+                    if code_nature_analyse.is_price_too_high_in_days(code, volumes_data, limit_up_price)[0]:
                         # 鍒ゆ柇鏄惁澶珮
                         l2_trade_util.forbidden_trade(code, "6澶╁唴鑲′环闀垮緱澶珮")
                         continue
-                        pass
+
+                    if tool.is_ge_code(code) and float(limit_up_price) < 10:
+                        l2_trade_util.forbidden_trade(code, "鍒涗笟鏉胯偂浠�10鍧楀唴")
 
                     if len(k_format) > 14 and k_format[14]:
                         l2_trade_util.forbidden_trade(code, "鏄ㄦ棩鐐告澘")

--
Gitblit v1.8.0