From 1c76abc59af35931b70b4742038dae0cfe4890d4 Mon Sep 17 00:00:00 2001 From: Administrator <admin@example.com> Date: 星期二, 18 七月 2023 16:28:18 +0800 Subject: [PATCH] 华鑫适配 --- l2/l2_data_manager_new.py | 114 +++++++++++++++++++++++++++++++++++++++++---------------- 1 files changed, 82 insertions(+), 32 deletions(-) diff --git a/l2/l2_data_manager_new.py b/l2/l2_data_manager_new.py index 9bde625..edfde48 100644 --- a/l2/l2_data_manager_new.py +++ b/l2/l2_data_manager_new.py @@ -5,13 +5,15 @@ limit_up_time_manager, global_data_loader, gpcode_manager import constant from l2.huaxin import l2_huaxin_util, huaxin_delegate_postion_manager +from third_data import kpl_data_manager from utils import global_util, ths_industry_util, tool import l2_data_util from db import redis_manager from third_data.code_plate_key_manager import CodePlateKeyBuyManager from trade import trade_manager, trade_queue_manager, l2_trade_factor, l2_trade_util, \ - trade_result_manager, first_code_score_manager -from l2 import safe_count_manager, l2_data_manager, l2_data_log, l2_log, l2_data_source_util, code_price_manager + trade_result_manager, first_code_score_manager, current_price_process_manager +from l2 import safe_count_manager, l2_data_manager, l2_data_log, l2_log, l2_data_source_util, code_price_manager, \ + transaction_progress from l2.cancel_buy_strategy import SecondCancelBigNumComputer, HourCancelBigNumComputer, L2LimitUpMoneyStatisticUtil, \ L2LimitUpSellStatisticUtil, DCancelBigNumComputer from l2.l2_data_manager import L2DataException, TradePointManager @@ -160,6 +162,7 @@ __buyL2SafeCountManager = safe_count_manager.BuyL2SafeCountManager() __l2PlaceOrderParamsManagerDict = {} __last_buy_single_dict = {} + __TradeBuyQueue = transaction_progress.TradeBuyQueue() # 鑾峰彇浠g爜璇勫垎 @classmethod @@ -711,37 +714,54 @@ if gpcode_manager.PauseBuyCodesManager.is_in(code): return False, True, f"璇ヤ唬鐮佽鏆傚仠浜ゆ槗" - # 鍒ゆ柇涔�1浠锋牸妗d綅 - zyltgb = global_util.zyltgb_map.get(code) - if zyltgb is None: - global_data_loader.load_zyltgb() - zyltgb = global_util.zyltgb_map.get(code) - limit_up_price = gpcode_manager.get_limit_up_price(code) + if constant.L2_SOURCE_TYPE == constant.L2_SOURCE_TYPE_HUAXIN: + trade_price = current_price_process_manager.get_trade_price(code) + if trade_price is None: + return False, True, f"灏氭湭鑾峰彇鍒板綋鍓嶆垚浜や环" + if float(limit_up_price) - float(trade_price) > 0.02001: + return False, False, f"褰撳墠鎴愪氦浠凤紙{trade_price}锛夊皻鏈湪2妗e強浠ュ唴" - if zyltgb >= 200 * 100000000: - buy1_price = code_price_manager.Buy1PriceManager.get_buy1_price(code) - if buy1_price is None: - return False, True, f"灏氭湭鑾峰彇鍒颁拱1浠�" - dif = float(limit_up_price) - float(buy1_price) - # 澶т簬10妗� - if dif > 0.10001: - return False, True, f"鑷敱娴侀��200浜夸互涓婏紝涔�1鍓╀綑妗f暟澶т簬10妗o紝涔颁竴锛坽buy1_price}锛夋定鍋滐紙{limit_up_price}锛�" - # elif zyltgb >= 80 * 100000000: - # # 澶т簬2妗� - # if dif > 0.02001: - # return False, True, f"涔�1鍓╀綑妗f暟澶т簬2妗o紝涔颁竴锛坽buy1_price}锛夋定鍋滐紙{limit_up_price}锛�" - # elif zyltgb >= 60 * 100000000: - # # 澶т簬2妗� - # if dif > 0.03001: - # return False, True, f"涔�1鍓╀綑妗f暟澶т簬3妗o紝涔颁竴锛坽buy1_price}锛夋定鍋滐紙{limit_up_price}锛�" - # elif zyltgb >= 40 * 100000000: - # # 澶т簬2妗� - # if dif > 0.04001: - # return False, True, f"涔�1鍓╀綑妗f暟澶т簬4妗o紝涔颁竴锛坽buy1_price}锛夋定鍋滐紙{limit_up_price}锛�" - # else: - # if dif > 0.05001: - # return False, True, f"涔�1鍓╀綑妗f暟澶т簬5妗o紝涔颁竴锛坽buy1_price}锛夋定鍋滐紙{limit_up_price}锛�" + # 鍒ゆ柇鎴愪氦杩涘害鏄惁璺濈鎴戜滑鐨勪綅缃緢杩� + total_data = local_today_datas.get(code) + trade_index, is_default = cls.__TradeBuyQueue.get_traded_index(code) + if not is_default and trade_index: + buy_index_set = set() + num_operate_map = local_today_num_operate_map.get(code) + for i in range(trade_index + 1, total_data[-1]["index"] + 1): + if L2DataUtil.is_limit_up_price_buy(total_data[i]["val"]): + left_count = l2_data_source_util.L2DataSourceUtils.get_limit_up_buy_no_canceled_count(code, + total_data[ + i][ + "index"], + total_data, + num_operate_map) + if left_count > 0: + buy_index_set.add(total_data[i]["index"]) + + if len(buy_index_set) < 5: + return False, False, f"鎴愪氦浣嶇疆璺濈褰撳墠浣嶇疆灏忎簬5绗�" + else: + # 鍒ゆ柇涔�1浠锋牸妗d綅 + zyltgb = global_util.zyltgb_map.get(code) + if zyltgb is None: + global_data_loader.load_zyltgb() + zyltgb = global_util.zyltgb_map.get(code) + + if zyltgb >= 200 * 100000000: + buy1_price = code_price_manager.Buy1PriceManager.get_buy1_price(code) + if buy1_price is None: + return False, True, f"灏氭湭鑾峰彇鍒颁拱1浠�" + dif = float(limit_up_price) - float(buy1_price) + # 澶т簬10妗� + if dif > 0.10001: + return False, True, f"鑷敱娴侀��200浜夸互涓婏紝涔�1鍓╀綑妗f暟澶т簬10妗o紝涔颁竴锛坽buy1_price}锛夋定鍋滐紙{limit_up_price}锛�" + + open_limit_up_lowest_price = code_price_manager.Buy1PriceManager.get_open_limit_up_lowest_price(code) + price_pre_close = gpcode_manager.get_price_pre(code) + if open_limit_up_lowest_price and ( + float(open_limit_up_lowest_price) - price_pre_close) / price_pre_close < 0.05: + return False, True, f"鐐告澘鍚庢渶浣庝环璺岃嚦5%浠ヤ笅" limit_up_info = code_price_manager.Buy1PriceManager.get_limit_up_info(code) if limit_up_info[0] is None and False: @@ -783,13 +803,43 @@ @classmethod def can_buy_first(cls, code, limit_up_price, score_index, score, score_info, volume_rate_info): + def is_has_k_format(score_info): + # (15涓氦鏄撴棩娑ㄥ箙鏄惁澶т簬24.9%,鏄惁鐮村墠楂橈紝鏄惁瓒呰穼锛屾槸鍚︽帴杩戝墠楂橈紝鏄惁N,鏄惁V,鏄惁鏈夊舰鎬�,澶╅噺澶ч槼淇℃伅,鏄惁鍏锋湁杈ㄨ瘑搴�) + + if score_info[1][3][6][0] and not score_info[1][3][3][0]: + return True + if score_info[1][3][7][0]: + return True + return False + if float(limit_up_price) >= 40: return False, True, "鑲′环澶т簬40鍧�" + # 鑾峰彇娑ㄥ仠 + latest_2_day_limit_up_datas_temp = kpl_data_manager.get_current_limit_up_data_records(2) + latest_2_day_limit_up_datas = [] + for d in latest_2_day_limit_up_datas_temp: + latest_2_day_limit_up_datas.extend(d[1]) # 鍒ゆ柇鏉垮潡 - plate_can_buy, msg = CodePlateKeyBuyManager.can_buy(code) + plate_can_buy, msg, block_type = CodePlateKeyBuyManager.can_buy(code, + kpl_data_manager.KPLLimitUpDataRecordManager.latest_origin_datas, + latest_2_day_limit_up_datas, + kpl_data_manager.KPLLimitUpDataRecordManager.total_datas) if not plate_can_buy: return False, True, msg + has_k_format = is_has_k_format(score_info) + # 鐙嫍 + if block_type == CodePlateKeyBuyManager.BLOCK_TYPE_START_UP: + # 蹇呴』婊¤冻锛堝垎鏁扳墺150涓斾笂鏉挎椂閲忊墺40 % 涓旀湁K绾垮舰鎬侊級鎴栵紙鍏锋湁杈ㄨ瘑搴︼級鐨勬墠鑳戒拱 + if has_k_format and score_index >= 0 and volume_rate_info[0] >= 0.4: + return True, False, "鐙嫍锛氬垎鏁扳墺150涓斾笂鏉挎椂閲忊墺40% 涓旀湁K绾垮舰鎬�" + elif score_info[1][3][8][0]: + return True, False, "鐙嫍锛氬叿鏈夎鲸璇嗗害" + else: + return False, True, f"鐙嫍锛氫笉婊¤冻涔板叆鏉′欢" + else: + return True, False, msg + # if volume_rate_info[0] < 0.4: # return False, True, f"閲忓ぇ浜�40%鎵嶄笅鍗�,閲忔瘮锛歿volume_rate_info[0]}" -- Gitblit v1.8.0