返回列表 发布新帖

全推订阅实盘示例,测试报错

15 0
发表于 4 小时前 | 显示全部楼层 阅读模式
全推订阅实盘实例报错:
备注:由于MacBookPro安装win10只有C盘,全部文件夹设置管理员权限。

2025-10-20 11:52:46.464 [id:1][测试打板]开始运行
2025-10-20 11:52:51.815 [id:1][测试打板]start

2025-10-20 11:52:51.878 [id:1][测试打板]建立交易连接,返回0表示连接成功 0

2025-10-20 11:52:51.879 [id:1][测试打板]对交易回调进行订阅,订阅后可以收到交易主推,返回0表示订阅成功 -1

2025-10-20 11:52:52.681 [id:1][测试打板]subscribe_quote callback error: <function f at 0x000002F0F86D1E18>

2025-10-20 11:52:52.682 [id:1][测试打板]Traceback (most recent call last):

2025-10-20 11:52:52.682 [id:1][测试打板]  File "C:\work\qmt\国金QMT交易端模拟\bin.x64\lib\site-packages\xtquant\xtdata.py", line 702, in subscribe_callback
    callback(datas)
  File "C:/work\qmt\国金QMT交易端模拟/mpython\测试打板.py", line 26, in f
    cuurent_price = data[stock][0]['lastPrice']
KeyError: 0

2025-10-20 11:52:53.002 [id:1][测试打板]subscribe_quote callback error: <function f at 0x000002F0F86D1E18>

2025-10-20 11:52:53.002 [id:1][测试打板]Traceback (most recent call last):

2025-10-20 11:52:53.002 [id:1][测试打板]  File "C:\work\qmt\国金QMT交易端模拟\bin.x64\lib\site-packages\xtquant\xtdata.py", line 702, in subscribe_callback
    callback(datas)
  File "C:/work\qmt\国金QMT交易端模拟/mpython\测试打板.py", line 26, in f
    cuurent_price = data[stock][0]['lastPrice']
KeyError: 0


=======================================================================================================
代码如下:

#coding:utf-8
import time, datetime, traceback, sys
from xtquant import xtdata
from xtquant.xttrader import XtQuantTrader, XtQuantTraderCallback
from xtquant.xttype import StockAccount
from xtquant import xtconstant

#定义一个类 创建类的实例 作为状态的容器
class _a():
    pass
A = _a()
A.bought_list = []
A.hsa = xtdata.get_stock_list_in_sector('沪深A股')

def interact():
    """执行后进入repl模式"""
    import code
    code.InteractiveConsole(locals=globals()).interact()
xtdata.download_sector_data()

def f(data):
    now = datetime.datetime.now()
    for stock in data:
        if stock not in A.hsa:
            continue
        cuurent_price = data[stock][0]['lastPrice']
        pre_price = data[stock][0]['lastClose']
        print(f"{stock}最新价{pre_price}")
        ratio = cuurent_price / pre_price - 1 if pre_price > 0 else 0
        if ratio > 0.09 and stock not in A.bought_list:
            print(f"{now} 最新价 买入 {stock} 200股")
            async_seq = xt_trader.order_stock_async(acc, stock, xtconstant.STOCK_BUY, 200, xtconstant.LATEST_PRICE, -1, 'strategy_name', stock)
            A.bought_list.append(stock)
   
class MyXtQuantTraderCallback(XtQuantTraderCallback):
    def on_disconnected(self):
        """
        连接断开
        :return:
        """
        print(datetime.datetime.now(),'连接断开回调')

    def on_stock_order(self, order):
        """
        委托回报推送
        :param order: XtOrder对象
        :return:
        """
        print(datetime.datetime.now(), '委托回调', order.order_remark)


    def on_stock_trade(self, trade):
        """
        成交变动推送
        :param trade: XtTrade对象
        :return:
        """
        print(datetime.datetime.now(), '成交回调', trade.order_remark)


    def on_order_error(self, order_error):
        """
        委托失败推送
        :param order_error:XtOrderError 对象
        :return:
        """
        # print("on order_error callback")
        # print(order_error.order_id, order_error.error_id, order_error.error_msg)
        print(f"委托报错回调 {order_error.order_remark} {order_error.error_msg}")

    def on_cancel_error(self, cancel_error):
        """
        撤单失败推送
        :param cancel_error: XtCancelError 对象
        :return:
        """
        print(datetime.datetime.now(), sys._getframe().f_code.co_name)

    def on_order_stock_async_response(self, response):
        """
        异步下单回报推送
        :param response: XtOrderResponse 对象
        :return:
        """
        print(f"异步委托回调 {response.order_remark}")

    def on_cancel_order_stock_async_response(self, response):
        """
        :param response: XtCancelOrderResponse 对象
        :return:
        """
        print(datetime.datetime.now(), sys._getframe().f_code.co_name)

    def on_account_status(self, status):
        """
        :param response: XtAccountStatus 对象
        :return:
        """
        print(datetime.datetime.now(), sys._getframe().f_code.co_name)


if __name__ == '__main__':
    print("start")
    #指定客户端所在路径,
    # 注意:如果是连接投研端进行交易,文件目录需要指定到f"{安装目录}\userdata"
    path = r'C:\work\qmt\国金QMT交易端模拟\userdata_mini'
    # 生成session id 整数类型 同时运行的策略不能重复
    session_id = int(time.time())
    xt_trader = XtQuantTrader(path, session_id)
    # 开启主动请求接口的专用线程 开启后在on_stock_xxx回调函数里调用XtQuantTrader.query_xxx函数不会卡住回调线程,但是查询和推送的数据在时序上会变得不确定
    # 详见: http://docs.thinktrader.net/vip/pages/ee0e9b/#开启主动请求接口的专用线程
    # xt_trader.set_relaxed_response_order_enabled(True)

    # 创建资金账号为 800068 的证券账号对象
    acc = StockAccount('800068', 'STOCK')
    # 创建交易回调类对象,并声明接收回调
    callback = MyXtQuantTraderCallback()
    xt_trader.register_callback(callback)
    # 启动交易线程
    xt_trader.start()
    # 建立交易连接,返回0表示连接成功
    connect_result = xt_trader.connect()
    print('建立交易连接,返回0表示连接成功', connect_result)
    # 对交易回调进行订阅,订阅后可以收到交易主推,返回0表示订阅成功
    subscribe_result = xt_trader.subscribe(acc)
    print('对交易回调进行订阅,订阅后可以收到交易主推,返回0表示订阅成功', subscribe_result)

    #这一行是注册全推回调函数 包括下单判断 安全起见处于注释状态 确认理解效果后再放开
    xtdata.subscribe_whole_quote(["SH", "SZ"], callback=f)
    # 阻塞主线程退出
    xt_trader.run_forever()
    # 如果使用vscode pycharm等本地编辑器 可以进入交互模式 方便调试 (把上一行的run_forever注释掉 否则不会执行到这里)
    interact()



回复

您需要登录后才可以回帖 登录 | 立即注册

客服专线

400-080-8112

用思考的速度交易,用真诚的态度合作,我们是认真的!
  • 关注公众号
  • 添加微信客服
Copyright © 2001-2025 迅投QMT社区 版权所有 All Rights Reserved. 京ICP备2025122616号-3
关灯 快速发帖
扫一扫添加微信客服
QQ客服返回顶部
快速回复 返回顶部 返回列表