From dc36d72459ea92e4c78e2a2eefb5655e82a3d459 Mon Sep 17 00:00:00 2001
From: Administrator <admin@example.com>
Date: 星期二, 04 六月 2024 23:52:26 +0800
Subject: [PATCH] 9:25之前的开1订阅

---
 l2/l2_transaction_data_manager.py |   83 ++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 80 insertions(+), 3 deletions(-)

diff --git a/l2/l2_transaction_data_manager.py b/l2/l2_transaction_data_manager.py
index 55c5792..9089d03 100644
--- a/l2/l2_transaction_data_manager.py
+++ b/l2/l2_transaction_data_manager.py
@@ -83,6 +83,17 @@
             return 0
         return int(sum([x[2] for x in self.__total_buy_datas_dict[code]]))
 
+    def get_total_buy_money_list(self, code):
+        """
+        鑾峰彇澶у崟鍒楄〃
+        @param code:
+        @return:
+        """
+        if code not in self.__total_buy_datas_dict:
+            return 0
+        return [x[2] for x in self.__total_buy_datas_dict[code]]
+
+
     def get_total_sell_money(self, code):
         """
         鑾峰彇鎬诲叡鐨勫ぇ鍗曞崠閲戦
@@ -149,9 +160,10 @@
         缁熻澶у崟涔�
         @param code:
         @param datas:
-        @return: 杩斿洖鏁版嵁閲岄潰鎴愪氦鐨勫ぇ鍗�
+        @return: 杩斿洖鏁版嵁閲岄潰(鎴愪氦鐨勫ぇ鍗�,50w浠ヤ笂鐨勫崟锛�
         """
         big_buy_datas = []
+        normal_buy_datas = []
         for data in datas:
             # q.append((data['SecurityID'], data['TradePrice'], data['TradeVolume'],
             #                   data['OrderTime'], data['MainSeq'], data['SubSeq'], data['BuyNo'],
@@ -174,9 +186,12 @@
                 # 鏄惁涓哄ぇ涔板崟
                 if deal_info[2] >= 2990000:
                     big_buy_datas.append(deal_info)
+                if deal_info[2] >= 500000:
+                    normal_buy_datas.append(deal_info)
+
                 # 鍒濆鍖栨湰鏉℃暟鎹�
                 cls.__dealing_order_info_dict[code] = [data[6], data[2], data[2] * data[1], data[3], data[3]]
-        return big_buy_datas
+        return big_buy_datas, normal_buy_datas
 
 
 # 鍗栧崟缁熻鏁版嵁
@@ -237,6 +252,56 @@
                 # 鍒濆鍖栨湰鏉℃暟鎹�
                 cls.__dealing_order_info_dict[code] = [data[7], data[2], data[2] * data[1]]
         return big_sell_datas
+
+    # 缁熻鎵�鏈夌殑鎴愪氦閲�
+    __deal_volume_list_dict = {}
+
+    @classmethod
+    def statistic_total_deal_volume(cls, code, datas):
+        # 鍙粺璁¤鍔ㄤ拱
+        if code not in cls.__deal_volume_list_dict:
+            cls.__deal_volume_list_dict[code] = []
+        time_dict = {}
+        for d in datas:
+            # 鍙粺璁¤鍔ㄤ拱
+            if d[7] < d[6]:
+                continue
+            time_str = ''
+            if d[3] in time_dict:
+                time_str = time_dict[d[3]]
+            else:
+                time_dict[d[3]] = l2_huaxin_util.convert_time(d[3])
+                time_str = time_dict[d[3]]
+            if cls.__deal_volume_list_dict[code]:
+                if cls.__deal_volume_list_dict[code][-1][0] == time_str:
+                    # 濡傛灉鏄悓涓�绉�
+                    cls.__deal_volume_list_dict[code][-1][1] += d[2]
+                else:
+                    # 涓嶆槸鍚屼竴绉�
+                    cls.__deal_volume_list_dict[code].append([time_str, d[2]])
+            else:
+                cls.__deal_volume_list_dict[code].append([time_str, d[2]])
+        # 鍒犻櫎瓒呰繃5鏉℃暟鎹�
+        if len(cls.__deal_volume_list_dict[code]) > 5:
+            cls.__deal_volume_list_dict[code] = cls.__deal_volume_list_dict[code][-5:]
+        time_dict.clear()
+
+    @classmethod
+    def get_latest_2s_continue_deal_volume(cls, code):
+        """
+        鑾峰彇鏈�杩戣繛缁�2s鐨勬垚浜ら噺
+        @param code:
+        @return: 鎴愪氦閲�,璇︾粏淇℃伅
+        """
+        deal_list = cls.__deal_volume_list_dict.get(code)
+        if not deal_list:
+            return 0, None
+        if len(deal_list) == 0:
+            return deal_list[0][1], deal_list
+        if tool.trade_time_sub(deal_list[-1][0], deal_list[-2][0]) > 1:
+            return deal_list[-1][1], deal_list
+        else:
+            return deal_list[-1][1] + deal_list[-2][1], deal_list
 
     # 杩斿洖鏈�杩�1s鐨勫ぇ鍗曞崠锛�(鎬诲崠閲戦,[(鍗栧崟鍙�,鎬绘墜鏁�,浠锋牸,锛�'寮�濮嬫椂闂�',涔板崟鍙凤級,锛�'缁撴潫鏃堕棿',涔板崟鍙凤級),...])
     @classmethod
@@ -374,7 +439,15 @@
 
     # 鑾峰彇鏈�杩戞垚浜ゆ暟鎹�
     @classmethod
-    def get_latest_transaction_datas(cls, code, min_sell_order_no=None, min_deal_time=None):
+    def get_latest_transaction_datas(cls, code, min_sell_order_no=None, min_deal_time=None, min_sell_money=None):
+        """
+        鑾峰彇鏈�杩戠殑涓诲姩鍗栨垚浜や俊鎭�
+        @param code:
+        @param min_sell_order_no:
+        @param min_deal_time:
+        @param min_sell_money:
+        @return:
+        """
         total_orders = []
         sell_orders = cls.__latest_all_sell_orders_dict.get(code)
         if sell_orders:
@@ -385,6 +458,10 @@
 
                 if min_sell_order_no and min_sell_order_no > sell_orders[i][0]:
                     continue
+                if min_sell_money and sell_orders[i][1] * sell_orders[i][2] < min_sell_money:
+                    # 杩囨护灏忛噾棰�
+                    continue
+
                 total_orders.append(sell_orders[i])
         if code in cls.__latest_sell_order_dict:
             if min_sell_order_no:

--
Gitblit v1.8.0