From 52c4cb753226d69e9ca04ff73ffa6e8ba79dd917 Mon Sep 17 00:00:00 2001
From: Administrator <admin@example.com>
Date: 星期三, 06 十二月 2023 16:36:35 +0800
Subject: [PATCH] 强势时间段调整

---
 code_attribute/first_target_code_data_processor.py |   53 ++++++++++++++++++++++++++++++++++-------------------
 1 files changed, 34 insertions(+), 19 deletions(-)

diff --git a/code_attribute/first_target_code_data_processor.py b/code_attribute/first_target_code_data_processor.py
index 4b7713e..5a2b739 100644
--- a/code_attribute/first_target_code_data_processor.py
+++ b/code_attribute/first_target_code_data_processor.py
@@ -5,16 +5,16 @@
 # 澶勭悊棣栨澘浠g爜淇℃伅
 
 import constant
-import inited_data
 from code_attribute import gpcode_manager, gpcode_first_screen_manager, code_nature_analyse, \
     code_volumn_manager
 from code_attribute.code_data_util import ZYLTGBUtil
+from code_attribute.code_nature_analyse import HighIncreaseCodeManager
 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
 from ths import l2_code_operate
 from trade import trade_data_manager, l2_trade_util
-from utils import global_util, tool
+from utils import global_util, tool, init_data_util
 
 __CodesPlateKeysManager = CodesHisReasonAndBlocksManager()
 
@@ -43,7 +43,7 @@
                 # 鑾峰彇娑ㄥ仠浠�
                 _limit_up_price = gpcode_manager.get_limit_up_price(code)
                 if not _limit_up_price:
-                    inited_data.re_set_price_pres([code], True)
+                    init_data_util.re_set_price_pres([code], True)
                     # 鍐嶆鑾峰彇娑ㄥ仠浠�
                     _limit_up_price = gpcode_manager.get_limit_up_price(code)
                 if _limit_up_price:
@@ -80,7 +80,7 @@
     for code in codes:
         # 濡傛灉娑ㄥ仠浠锋槸绌哄�煎氨闇�瑕佽缃槰鏃ユ敹鐩樹环鏍�
         if gpcode_manager.get_limit_up_price(code) is None:
-            inited_data.re_set_price_pres([code], True)
+            init_data_util.re_set_price_pres([code], True)
 
     # 鏉垮潡鍏抽敭瀛楀噯澶�  鏆傛椂鍒犻櫎
     # for code in codes:
@@ -111,16 +111,36 @@
             if limit_up_price is None:
                 continue
             try:
-                volumes_data = inited_data.get_volumns_by_code(code, 150)
-                volumes = inited_data.parse_max_volume(volumes_data[:90],
-                                                       code_nature_analyse.is_new_top(
-                                                           limit_up_price,
-                                                           volumes_data[:90]))
+                volumes_data = init_data_util.get_volumns_by_code(code, 150)
+                volumes = init_data_util.parse_max_volume(volumes_data[:90],
+                                                          code_nature_analyse.is_new_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])
-                if code_nature_analyse.is_up_too_high(volumes_data):
+
+                # 淇濆瓨K绾垮舰鎬�
+                k_format = code_nature_analyse.get_k_format(limit_up_price, volumes_data)
+                code_nature_analyse.CodeNatureRecordManager().save_k_format(code, k_format)
+
+                if code_nature_analyse.is_up_too_high_in_10d_with_limit_up(volumes_data):
                     # 鍒ゆ柇鏄惁澶珮
-                    l2_trade_util.forbidden_trade(code, "鑲′环闀垮緱澶珮")
+                    # 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)
+
+                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澶╂槸鍚︽槸鏈�楂橀噺
+                    code_nature_analyse.LatestMaxVolumeManager().set_has_latest_max_volume(code)
 
                 # 鍒ゆ柇K绾垮舰鎬�
                 # is_has_k_format, msg = code_nature_analyse.is_has_k_format(
@@ -170,7 +190,7 @@
     # 鑾峰彇娑ㄥ仠浠�
     if temp_codes:
         # 鑾峰彇娑ㄥ仠浠�
-        inited_data.re_set_price_pres(temp_codes)
+        init_data_util.re_set_price_pres(temp_codes)
         # 閲嶆柊鑾峰彇娑ㄥ仠浠�
         for code in temp_codes:
             limit_up_price = gpcode_manager.get_limit_up_price(code)
@@ -196,19 +216,14 @@
             gpcode_manager.FirstCodeManager().add_limited_up_record([code])
         pricePre = gpcode_manager.CodePrePriceManager.get_price_pre_cache(code)
         if pricePre is None:
-            inited_data.re_set_price_pres([code])
+            init_data_util.re_set_price_pres([code])
 
         rate = round((float(price) - pricePre) * 100 / pricePre, 1)
         prices.append(
             {"code": code, "time": limit_up_time, "rate": rate,
              "limit_up": is_limit_up})
-        if code in new_add_codes:
-            if is_limit_up:
-                place_order_count = trade_data_manager.PlaceOrderCountManager().get_place_order_count(
-                    code)
-                if place_order_count == 0:
-                    trade_data_manager.PlaceOrderCountManager().place_order(code)
 
     gpcode_first_screen_manager.process_ticks(prices)
     logger_l2_codes_subscript.info(f"({request_id})l2浠g爜鐩稿叧鏁版嵁鍔犺浇瀹屾垚")
     return tick_datas
+

--
Gitblit v1.8.0