From ae8d76a456b64c1c6c4ebf11b6ec33b7df217b1a Mon Sep 17 00:00:00 2001
From: Administrator <admin@example.com>
Date: 星期一, 18 八月 2025 13:43:46 +0800
Subject: [PATCH] bug修复

---
 third_data/kpl_limit_up_data_manager.py |   31 ++++++++++++++++++++++---------
 1 files changed, 22 insertions(+), 9 deletions(-)

diff --git a/third_data/kpl_limit_up_data_manager.py b/third_data/kpl_limit_up_data_manager.py
index 3ffb3a1..3a100e9 100644
--- a/third_data/kpl_limit_up_data_manager.py
+++ b/third_data/kpl_limit_up_data_manager.py
@@ -126,8 +126,8 @@
     """
     鏈�杩戞定鍋滅殑鏉垮潡绠$悊
     """
-    # 鐪嬫渶杩�3澶╋紝涓嶅寘鍚粖澶�
-    __LATEST_DAY_COUNT = 3
+    # 鐪嬫渶杩�2澶╋紝涓嶅寘鍚粖澶�
+    __LATEST_DAY_COUNT = 2
 
     __days = []
     # 鐩墠娑ㄥ仠
@@ -202,7 +202,7 @@
             # 灏嗘澘鍧楁墍鍖呭惈鐨勪唬鐮佸綊绫�
             code = h[3]
             cls.__code_name_dict[code] = h[4]
-            blocks = LimitUpCodesBlockRecordManager().get_radical_buy_blocks(code)
+            blocks = {h[2]} #LimitUpCodesBlockRecordManager().get_radical_buy_blocks(code)
             if blocks:
                 for b in blocks:
                     if b not in block_codes_dict:
@@ -232,8 +232,8 @@
         block_codes_dict = {}
         for day in self.__block_day_datas:
             for b in self.__block_day_datas[day]:
-                total_limit_up_count = self.__block_day_datas[day][b][0] + self.__block_day_datas[day][b][1]
-                if total_limit_up_count < 3:
+                finally_limit_up_count = self.__block_day_datas[day][b][0]
+                if finally_limit_up_count < 3:
                     continue
                 # 鏉垮潡娑ㄥ仠涓暟
                 if b not in block_count_dict:
@@ -242,9 +242,9 @@
                     block_codes_dict[b] = set()
                 block_count_dict[b].add(day)
                 block_codes_dict[b] |= self.__block_day_datas[day][b][2]
-
+        # [(鏉垮潡,娑ㄥ仠鏃ユ湡闆嗗悎)]
         block_count_list = [(k, block_count_dict[k]) for k in block_count_dict]
-        block_count_list.sort(key=lambda x: x[1], reverse=True)
+        block_count_list.sort(key=lambda x: len(x[1]), reverse=True)
         block_count_list = block_count_list[:50]
         # [(娑ㄥ仠鍘熷洜,绱娑ㄥ仠娆℃暟,杩炵画娆℃暟)]
         fdatas = []
@@ -257,6 +257,11 @@
                 if day not in self.__block_day_datas:
                     continue
                 if b in self.__block_day_datas[day]:
+                    finally_limit_up_count = self.__block_day_datas[day][b][0]
+                else:
+                    finally_limit_up_count = 0
+                if b in self.__block_day_datas[day] and finally_limit_up_count >= 3:
+                    # 鏉垮潡浠g爜鏁伴噺>=3涓�
                     temp.append(day)
                 else:
                     c = len(temp)
@@ -308,10 +313,10 @@
         if cls.__days:
             volumes_data = HistoryKDataManager().get_history_bars(code, cls.__days[1])
             if volumes_data:
-                volumes_data = volumes_data[:cls.__LATEST_DAY_COUNT - 1]
+                volumes_data = volumes_data[:cls.__LATEST_DAY_COUNT]
                 cls.__k_datas[code] = volumes_data
         if not volumes_data:
-            volumes_data = init_data_util.get_volumns_by_code(code, cls.__LATEST_DAY_COUNT - 1)
+            volumes_data = init_data_util.get_volumns_by_code(code, cls.__LATEST_DAY_COUNT)
             if volumes_data:
                 cls.__k_datas[code] = volumes_data
         # 鑾峰彇鏈�澶ф定骞�
@@ -322,3 +327,11 @@
         rate = int((volumes_data[0]["close"] - min_price) * 100 / min_price)
         cls.__k_max_rate[code] = rate
         return cls.__k_datas.get(code)
+
+
+if __name__ == "__main__":
+    # datas = LatestLimitUpBlockManager().statistics_limit_up_block_infos()
+    # print(datas)
+    code = "600126"
+    blocks = LimitUpCodesBlockRecordManager().get_radical_buy_blocks(code)
+    print(blocks)
\ No newline at end of file

--
Gitblit v1.8.0