tqsdk.TqKq - 快期模拟交易类
- class tqsdk.TqKq(td_url: str | None = None, number: int | None = None)
天勤快期模拟账户类
创建快期模拟账户实例
快期模拟的账户和交易信息可以在快期专业版, 快期v2, 快期v3, 快期APP查看
- Args:
td_url (str): [可选]指定交易服务器的地址, 默认使用快期账户对应的交易服务地址
number (int): [可选]模拟交易账号编号, 默认为主模拟账号, 可以通过指定 1~99 的数字来使用辅模拟帐号, 各个帐号的数据完全独立, 使用该功能需要购买专业版的权限, 且对应的辅账户可以在快期专业版上登录并进行观察
Example1:
from tqsdk import TqApi, TqAuth, TqKq tq_kq = TqKq() api = TqApi(account=tq_kq, auth=TqAuth("快期账户", "账户密码")) quote = api.get_quote("SHFE.cu2206") print(quote) # 下单限价单 order = api.insert_order(symbol="SHFE.cu2206", direction='BUY', offset='OPEN', limit_price=quote.last_price, volume=1) while order.status == 'ALIVE': api.wait_update() print(order) # 打印委托单信息 print(tq_kq.get_account()) # 打印快期模拟账户信息 print(tq_kq.get_position("SHFE.cu2206")) # 打印持仓信息 for trade in order.trade_records.values(): print(trade) # 打印委托单对应的成交信息 api.close()
Example2:
from tqsdk import TqApi, TqAuth, TqKq, TqMultiAccount # 创建快期模拟账户和辅模拟账户001 tq_kq = TqKq() tq_kq001= TqKq(number=1) # 使用多账户模块同时登录这两个模拟账户 api = TqApi(account=TqMultiAccount([tq_kq,tq_kq001]), auth=TqAuth("快期账户", "账户密码")) print(tq_kq.get_account()) # 打印快期模拟账户信息 print(tq_kq001.get_account()) # 打印快期模拟001账户信息 api.close()
- get_account() Account
获取用户账户资金信息
- Returns:
Account
: 返回一个账户对象引用. 其内容将在wait_update()
时更新
Example1:
# 获取当前浮动盈亏 from tqsdk import TqApi, TqAuth tqacc = TqAccount("N南华期货", "123456", "123456") api = TqApi(account=tqacc, auth=TqAuth("快期账户", "账户密码")) account = tqacc.get_account() print(account.float_profit) # 预计的输出是这样的: 2180.0 ...
Example2:
# 多账户模式下, 分别获取各账户浮动盈亏 from tqsdk import TqApi, TqAuth, TqMultiAccount, TqAccount, TqKq, TqSim account = TqAccount("N南华期货", "123456", "123456") tqkq = TqKq() tqsim = TqSim() api = TqApi(TqMultiAccount([account, tqkq, tqsim]), auth=TqAuth("快期账户", "账户密码")) account1 = account.get_account() account2 = tqkq.get_account() account3 = tqsim.get_account() print(f"账户 1 浮动盈亏 {account1.float_profit}, 账户 2 浮动盈亏 {account2.float_profit}, 账户 3 浮动盈亏 {account3.float_profit}") api.close()
- get_order(order_id: str | None = None) Order | Entity
获取用户委托单信息
- Args:
order_id (str): [可选]单号, 不填单号则返回所有委托单
- Returns:
Order
: 当指定了 order_id 时, 返回一个委托单对象引用。 其内容将在wait_update()
时更新。不填 order_id 参数调用本函数, 将返回包含用户所有委托单的一个
tqsdk.objs.Entity
对象引用, 使用方法与dict一致, 其中每个元素的key为委托单号, value为Order
注意: 在刚下单后, tqsdk 还没有收到回单信息时, 此对象中各项内容为空
Example1:
# 获取当前总挂单手数 from tqsdk import TqApi, TqAuth tqacc = TqAccount("N南华期货", "123456", "123456") api = TqApi(account=tqacc, auth=TqAuth("快期账户", "账户密码")) orders = tqacc.get_order() while True: api.wait_update() print(sum(order.volume_left for oid, order in orders.items() if order.status == "ALIVE")) # 预计的输出是这样的: 3 3 0 ...
Example2:
# 多账户模式下, 分别获取各账户挂单手数 from tqsdk import TqApi, TqAuth, TqMultiAccount, TqAccount, TqKq, TqSim account = TqAccount("N南华期货", "123456", "123456") tqkq = TqKq() tqsim = TqSim() api = TqApi(TqMultiAccount([account, tqkq, tqsim]), auth=TqAuth("快期账户", "账户密码")) orders1 = account.get_order() orders2 = tqkq.get_order() orders3 = tqsim.get_order() print(f"账户 1 挂单手数 {sum(order.volume_left for order in orders1.values() if order.status == "ALIVE")}, ", f"账户 2 挂单手数 {sum(order.volume_left for order in orders2.values() if order.status == "ALIVE")}, ", f"账户 3 挂单手数 {sum(order.volume_left for order in orders3.values() if order.status == "ALIVE")}") order = account.get_order(order_id="订单号") print(order) api.close()
- get_position(symbol: str | None = None) Position | Entity
获取用户持仓信息
- Args:
symbol (str): [可选]合约代码, 不填则返回所有持仓
- Returns:
Position
: 当指定了 symbol 时, 返回一个持仓对象引用。 其内容将在wait_update()
时更新。不填 symbol 参数调用本函数, 将返回包含用户所有持仓的一个
tqsdk.objs.Entity
对象引用, 使用方法与dict一致, 其中每个元素的 key 为合约代码, value 为Position
。注意: 为保留一些可供用户查询的历史信息, 如 volume_long_yd(本交易日开盘前的多头持仓手数) 等字段, 因此服务器会返回当天已平仓合约( pos_long 和 pos_short 等字段为0)的持仓信息
Example1:
# 获取 DCE.m2109 当前浮动盈亏 from tqsdk import TqApi, TqAuth, TqAccount tqacc = TqAccount("N南华期货", "123456", "123456") api = TqApi(account=tqacc, auth=TqAuth("快期账户", "账户密码")) position = tqacc.get_position("DCE.m2109") print(position.float_profit_long + position.float_profit_short) while api.wait_update(): print(position.float_profit_long + position.float_profit_short) # 预计的输出是这样的: 300.0 330.0 ...
Example2:
# 多账户模式下, 分别获取各账户浮动盈亏 from tqsdk import TqApi, TqAuth, TqMultiAccount, TqAccount, TqKq, TqSim account = TqAccount("N南华期货", "123456", "123456") tqkq = TqKq() tqsim = TqSim() api = TqApi(TqMultiAccount([account, tqkq, tqsim]), auth=TqAuth("快期账户", "账户密码")) position1 = account.get_position("DCE.m2101") position2 = tqkq.get_position("DCE.m2101") position3 = tqsim.get_position("DCE.m2101") print(f"账户 1 'DCE.m2101' 浮动盈亏 {position1.float_profit_long + position1.float_profit_short}, ", f"账户 2 'DCE.m2101' 浮动盈亏 {position2.float_profit_long + position2.float_profit_short}, ", f"账户 3 'DCE.m2101' 浮动盈亏 {position3.float_profit_long + position3.float_profit_short}") api.close()
- get_trade(trade_id: str | None = None) Trade | Entity
获取用户成交信息
- Args:
trade_id (str): [可选]成交号, 不填成交号则返回所有委托单
- Returns:
Trade
: 当指定了trade_id时, 返回一个成交对象引用. 其内容将在wait_update()
时更新.不填trade_id参数调用本函数, 将返回包含用户当前交易日所有成交记录的一个tqsdk.objs.Entity对象引用, 使用方法与dict一致, 其中每个元素的key为成交号, value为
Trade
推荐优先使用
trade_records()
获取某个委托单的相应成交记录, 仅当确有需要时才使用本函数.
Example:
# 多账户模式下, 分别获取各账户的成交记录 from tqsdk import TqApi, TqAuth, TqMultiAccount account = TqAccount("N南华期货", "123456", "123456") tqkq = TqKq() tqsim = TqSim() api = TqApi(TqMultiAccount([account, tqkq, tqsim]), auth=TqAuth("快期账户", "账户密码")) trades1 = account.get_trade() trades2 = tqkq.get_trade() trades3 = tqsim.get_trade() print(trades1) print(trades2) print(trades3) api.close()
tqsdk.TqKqStock - 快期股票模拟交易类
- class tqsdk.TqKqStock(td_url: str | None = None, number: int | None = None)
天勤实盘类
创建快期股票模拟账户实例
快期股票模拟为专业版功能,可以点击 天勤量化专业版 申请试用或购买
- Args:
td_url (str): [可选]指定交易服务器的地址, 默认使用快期账户对应的交易服务地址
number (int): [可选]模拟交易账号编号, 默认为主模拟账号, 可以通过指定 1~99 的数字来使用辅模拟帐号, 各个帐号的数据完全独立
Example:
from tqsdk import TqApi, TqAuth, TqKqStock, TqChan tq_kq_stock = TqKqStock() api = TqApi(account=tq_kq_stock, auth=TqAuth("快期账户", "账户密码")) quote = api.get_quote("SSE.688529") print(quote) # 下单限价单 order = api.insert_order("SSE.688529", volume=200, direction="BUY", limit_price=quote.ask_price1) while order.status == 'ALIVE': api.wait_update() print(order) # 打印委托单信息 print(tq_kq_stock.get_account()) # 打印快期股票模拟账户信息 print(tq_kq_stock.get_position("SSE.688529")) # 打印持仓信息 for trade in order.trade_records.values(): print(trade) # 打印委托单对应的成交信息 api.close()
- get_account() SecurityAccount
获取用户账户资金信息
- Returns:
SecurityAccount
: 返回一个账户对象引用. 其内容将在wait_update()
时更新
Example1:
# 获取当前浮动盈亏 from tqsdk import TqApi, TqAuth tqacc = TqAccount("N南华期货", "123456", "123456") api = TqApi(account=tqacc, auth=TqAuth("快期账户", "账户密码")) account = tqacc.get_account() print(account.float_profit) # 预计的输出是这样的: 2180.0 ...
Example2:
# 多账户模式下, 分别获取各账户浮动盈亏 from tqsdk import TqApi, TqAuth, TqMultiAccount, TqAccount, TqKq, TqSim account = TqAccount("N南华期货", "123456", "123456") tqkq = TqKq() tqsim = TqSim() api = TqApi(TqMultiAccount([account, tqkq, tqsim]), auth=TqAuth("快期账户", "账户密码")) account1 = account.get_account() account2 = tqkq.get_account() account3 = tqsim.get_account() print(f"账户 1 浮动盈亏 {account1.float_profit}, 账户 2 浮动盈亏 {account2.float_profit}, 账户 3 浮动盈亏 {account3.float_profit}") api.close()
- get_order(order_id: str | None = None) SecurityOrder | Entity
获取用户委托单信息
- Args:
order_id (str): [可选]单号, 不填单号则返回所有委托单
- Returns:
SecurityOrder
: 当指定了 order_id 时, 返回一个委托单对象引用。 其内容将在wait_update()
时更新。不填 order_id 参数调用本函数, 将返回包含用户所有委托单的一个
tqsdk.objs.Entity
对象引用, 使用方法与 dict 一致, 其中每个元素的 key 为委托单号, value为SecurityOrder
注意: 在刚下单后, tqsdk 还没有收到回单信息时, 此对象中各项内容为空
Example:
from tqsdk import TqApi, TqAuth, TqKqStock tqkqstock = TqKqStock() api = TqApi(account=tqkqstock, auth=TqAuth("快期账户", "账户密码")) order = tqkqstock.get_order('委托单Id') print(f"委托股数 {order.volume_orign}, 剩余股数 {order.volume_left}") api.close()
- get_position(symbol: str | None = None) SecurityPosition | Entity
获取用户持仓信息
- Args:
symbol (str): [可选]合约代码, 不填则返回所有持仓
- Returns:
SecurityPosition
: 当指定了 symbol 时, 返回一个持仓对象引用。 其内容将在wait_update()
时更新。不填 symbol 参数调用本函数, 将返回包含用户所有持仓的一个
tqsdk.objs.Entity
对象引用, 使用方法与dict一致, 其中每个元素的 key 为合约代码, value 为SecurityPosition
。
Example:
from tqsdk import TqApi, TqAuth, TqKqStock tqkqstock = TqKqStock() api = TqApi(account=tqkqstock, auth=TqAuth("快期账户", "账户密码")) position = tqkqstock.get_position('SSE.10003624') print(f"建仓日期 {position.create_date}, 持仓数量 {position.volume}") api.close()
- get_trade(trade_id: str | None = None) SecurityTrade | Entity
获取用户成交信息
- Args:
trade_id (str): [可选]成交号, 不填成交号则返回所有委托单
- Returns:
SecurityTrade
: 当指定了trade_id时, 返回一个成交对象引用. 其内容将在wait_update()
时更新.不填trade_id参数调用本函数, 将返回包含用户当前交易日所有成交记录的一个
tqsdk.objs.Entity
对象引用, 使用方法与dict一致, 其中每个元素的key为成交号, value为SecurityTrade
推荐优先使用
trade_records()
获取某个委托单的相应成交记录, 仅当确有需要时才使用本函数.
Example:
from tqsdk import TqApi, TqAuth, TqKqStock tqkqstock = TqKqStock() api = TqApi(account=tqkqstock, auth=TqAuth("快期账户", "账户密码")) trades = tqkqstock.get_trade('委托单Id') [print(trade.trade_id, f"成交股数 {trade.volume}, 成交价格 {trade.price}") for trade in trades] api.close()