| | |
| | | from code_attribute import gpcode_manager |
| | | from db import redis_manager |
| | | from db.redis_manager_delegate import RedisUtils |
| | | from l2 import l2_data_util, l2_data_manager, transaction_progress |
| | | from l2 import l2_data_util, l2_data_manager, transaction_progress, l2_data_source_util |
| | | from l2.cancel_buy_strategy import LCancelRateManager, LCancelBigNumComputer, \ |
| | | SecondCancelBigNumComputer, HourCancelBigNumComputer, FastCancelBigNumComputer |
| | | from l2.l2_data_util import L2DataUtil |
| | | SecondCancelBigNumComputer, HourCancelBigNumComputer, \ |
| | | GCancelBigNumComputer, FCancelBigNumComputer |
| | | from l2.l2_data_manager_new import L2TradeDataProcessor |
| | | from l2.l2_data_util import L2DataUtil, local_today_canceled_buyno_map |
| | | from log_module import async_log_util |
| | | from log_module.log import logger_l2_trade_buy_queue, hx_logger_l2_upload, hx_logger_l2_debug, \ |
| | | hx_logger_l2_transaction_desc |
| | | hx_logger_l2_transaction_desc, logger_debug |
| | | from msg import push_msg_manager |
| | | from third_data import kpl_data_manager |
| | | from trade import current_price_process_manager, trade_manager, l2_trade_factor |
| | | from trade.deal_big_money_manager import DealOrderNoManager |
| | | from utils import tool |
| | |
| | | |
| | | order_begin_pos = l2_data_manager.TradePointManager().get_buy_compute_start_data_cache(code) |
| | | |
| | | if order_begin_pos and order_begin_pos.buy_exec_index and order_begin_pos.buy_exec_index > -1: |
| | | # 已经下单的需要统计F撤 |
| | | try: |
| | | for d in datas: |
| | | if FCancelBigNumComputer().need_cancel(d)[0]: |
| | | L2TradeDataProcessor.cancel_buy(code, f"F撤撤单:{d}") |
| | | order_begin_pos = None |
| | | break |
| | | except Exception as e: |
| | | async_log_util.error(hx_logger_l2_debug, str(e)) |
| | | try: |
| | | for d in datas: |
| | | if LCancelBigNumComputer().add_transaction_data(d)[0]: |
| | | L2TradeDataProcessor.cancel_buy(code, f"L后成交太快撤单:{d}") |
| | | order_begin_pos = None |
| | | break |
| | | except Exception as e: |
| | | async_log_util.error(hx_logger_l2_debug, str(e)) |
| | | |
| | | |
| | | # 计算已经成交的大单 |
| | | big_money_count = 0 |
| | | for d in datas: |
| | |
| | | buy_num = None |
| | | if data: |
| | | buy_num = data["val"]["num"] * 100 |
| | | # 统计成交单 |
| | | deal_info = self.__statistic_deal_desc(code, d, buy_num) |
| | | if deal_info and deal_info[1]: |
| | | data = buyno_map.get(f"{deal_info[0]}") |
| | |
| | | val = data["val"] |
| | | if l2_data_util.is_big_money(val) and L2DataUtil.is_limit_up_price_buy(val): |
| | | big_money_count += 1 |
| | | DealOrderNoManager().add_orderno(code, deal_info[0]) |
| | | DealOrderNoManager().add_orderno(code, f"{deal_info[0]}") |
| | | # L后是否有成交,如果有成交就需要除去当前笔数,然后重新囊括一笔 |
| | | LCancelBigNumComputer().add_deal_index(code, data["index"], order_begin_pos.buy_single_index) |
| | | if big_money_count > 0: |
| | | # 统计大单/m值成交比 |
| | | total_deal_nums = DealOrderNoManager().get_deal_nums(code, buyno_map) |
| | | thresh_hold_money = l2_trade_factor.L2PlaceOrderParamsManager.get_base_m_val(code) |
| | | limit_up_price = gpcode_manager.get_limit_up_price(code) |
| | | if limit_up_price: |
| | | rate = round(total_deal_nums / (thresh_hold_money // (float(limit_up_price) * 100)), 2) |
| | | LCancelRateManager().set_big_num_deal_rate(code, rate) |
| | | # 获取执行位时间 |
| | | LCancelRateManager.compute_big_num_deal_rate(code) |
| | | |
| | | buy_progress_index = self.__compute_latest_trade_progress(code, buyno_map, datas) |
| | | |
| | | if buy_progress_index is not None: |
| | | self.__TradeBuyQueue.set_traded_index(code, buy_progress_index, total_datas) |
| | | buy_progress_index_changed = self.__TradeBuyQueue.set_traded_index(code, buy_progress_index, |
| | | total_datas) |
| | | |
| | | async_log_util.info(logger_l2_trade_buy_queue, "获取成交位置成功: code-{} index-{}", code, |
| | | buy_progress_index) |
| | | |
| | | if buy_progress_index is not None: |
| | | GCancelBigNumComputer().set_trade_progress(code, order_begin_pos.buy_single_index, buy_progress_index) |
| | | |
| | | LCancelBigNumComputer().set_trade_progress(code, order_begin_pos.buy_single_index, buy_progress_index, |
| | | total_datas) |
| | | FastCancelBigNumComputer().set_trade_progress(code, buy_progress_index) |
| | | SecondCancelBigNumComputer().set_transaction_index( |
| | | code, |
| | | buy_progress_index) |
| | | if order_begin_pos and order_begin_pos.buy_exec_index and order_begin_pos.buy_exec_index > -1: |
| | | HourCancelBigNumComputer().set_transaction_index(code, order_begin_pos.buy_single_index, |
| | | buy_progress_index) |
| | | # ---------------------------------判断板块是否跟上来了------------------------------- |
| | | try: |
| | | pass |
| | | # order_begin_pos = l2_data_manager.TradePointManager().get_buy_compute_start_data_cache(code) |
| | | # volume_rate = 0 |
| | | # volume_info = L2TradeDataProcessor.volume_rate_info.get(code) |
| | | # if volume_info: |
| | | # volume_rate = volume_info[0] |
| | | # need_cancel, msg = UCancelBigNumComputer().need_cancel(code, buy_progress_index, order_begin_pos, |
| | | # kpl_data_manager.KPLLimitUpDataRecordManager.get_current_reason_codes_dict(), |
| | | # volume_rate) |
| | | # if need_cancel: |
| | | # L2TradeDataProcessor.cancel_buy(code, msg) |
| | | except Exception as e: |
| | | logger_debug.exception(e) |
| | | if buy_progress_index_changed: |
| | | # 交易进度变化,判断到真实下单位置的距离 |
| | | real_order_index = SecondCancelBigNumComputer().get_real_place_order_index_cache(code) |
| | | if real_order_index and real_order_index >= buy_progress_index: |
| | | left_count = 0 |
| | | for i in range(buy_progress_index + 1, real_order_index): |
| | | val = total_datas[i]["val"] |
| | | if not L2DataUtil.is_limit_up_price_buy(val): |
| | | continue |
| | | if val["num"] * float(val["price"]) < 5000: |
| | | continue |
| | | left_count = l2_data_source_util.L2DataSourceUtils.get_limit_up_buy_no_canceled_count_v2( |
| | | code, i, |
| | | total_datas, |
| | | local_today_canceled_buyno_map.get( |
| | | code)) |
| | | if left_count > 0: |
| | | left_count += 1 |
| | | if left_count <= 3: |
| | | # 当成交进度距离真实下单位置不足3笔时推送即将成交的消息 |
| | | push_msg_manager.push_order_almost_deal(code, gpcode_manager.get_code_name(code)) |
| | | |
| | | else: |
| | | pass |
| | | if order_begin_pos and order_begin_pos.buy_exec_index and order_begin_pos.buy_exec_index > -1: |