# 策略交易

策略交易相关的功能包括:

  • 交易接口、查询委托、查询交易回报
  • 查询资金信息、查询持仓信息
    交易接口面对策略的函数形式保持不变,策略运行与回测、仿真、实盘时,接口底层自动适配不同交易通道,策略无需做额外处理

# 订单数据结构说明

订数据是由交易接口返回的数据集,在接口调用成功时即生成,识别主键为 clOrdId,随之委托的成交进度,委托单的状会不断更新,但主键保持不变

属性 类型 说明
strategyId char 策略 ID
accountId char 账号 ID
accountName char 账户登录名
clOrdId char 委托客户端 ID,下单生成,固定不变,这个才是策略识别的主键
orderId char 委托柜台 ID(系统字段)
exOrdId char 委托交易所 ID(系统字段)
symbol char 标的代码
side double 买卖方向 取值参考 OrderSide
positionEffect double 开平标志 取值参考 PositionEffect
positionSide double 持仓方向 取值参考 PositionSide
orderType double 委托类型 取值参考 OrderType
orderDuration double 委托时间属性 取值参考 OrderDuration
orderQualifier double 委托成交属性 取值参考 OrderQualifier
orderSrc double 委托来源(系统字段)
status double 委托状态 取值参考 OrderStatus
ordRejReason double 委托拒绝原因 取值参考 OrderRejectReason
ordRejReasonDetail char 委托拒绝原因描述
price double 委托价格
stopPrice double 委托止损/止盈触发价格
orderStyle double 委托风格 取值参考 OrderStyle
volume double 委托量
value double 委托额
percent double 委托百分比
targetVolume double 委托目标量
targetValue double 委托目标额
targetPercent double 委托目标百分比
filledVolume double 已成量
filledVwap double 已成均价
filledAmount double 已成金额
filledCommission double 已成手续费
createdAt char 委托创建时间
updatedAt char 委托更新时间

# 回报数据结构说明

ExecRpt - 回报返回值字段

属性 类型 说明
strategyId char 策略 ID
accountId char 账号 ID
accountName char 账户登录名
clOrdId char 委托客户端 ID,下单生成,固定不变,这个才是策略识别的主键
orderId char 委托柜台 ID(系统字段)
ex_ord_id char 委托交易所 ID
positionEffect double 开平标志 取值参考 PositionEffect
side double 买卖方向 取值参考 OrderSide
ordRejReason double 委托拒绝原因 取值参考 OrderRejectReason
ordRejReasonDetail char 委托拒绝原因描述
execType double 执行回报类型 取值参考 ExecType
price double 委托成交价格
volume double 委托成交量
amount double 委托成交金额
createdAt char 回报创建时间

# 持仓数据结构说明

Position - 持仓返回值字段

属性 类型 说明
accountId char 账号 ID
accountName char 账户登录名
symbol char 标的代码
side double 持仓方向 取值参考 PositionSide
volume double 总持仓量; 昨持仓量 (volume - volume_today)
volumeToday double 今日持仓量
vwap double 持仓均价 new_vwap=((position.vwap * position.volume)+(trade.volume*trade.price))/(position.volume+trade.volume)
amount double 持仓额 (volumevwapmultiplier)
price double 当前行情价格(回测时值为 0)
fpnl double 持仓浮动盈亏 ((price - vwap) _ volume _ multiplier) (回测模式 fpnl 只有仓位变化时或者一天更新一次,仿真模式 3s 更新一次)
cost double 持仓成本 (vwap _ volume _ multiplier * margin_ratio)
orderFrozen double 挂单冻结仓位
orderFrozenToday double 挂单冻结今仓仓位
available double 非挂单冻结总仓位 (volume - order_frozen); 可平昨仓位 (available - available_today)(仅上期所和上海能源交易中心支持)
availableToday double 非挂单冻结今仓位 (volume_today - order_frozen_today)(仅上期所和上海能源交易中心支持)
availableNow double 当前可平仓位
lastPrice double 上一次成交价(回测时值为 0)
lastVolume double 上一次成交量(回测时值为 0)
lastInout double 上一次出入持仓量(回测时值为 0)
changeReason double 仓位变更原因, 取值参考 CashPositionChangeReason
changeEventId char 触发资金变更事件的 ID
hasDividend double 持仓区间有分红配送
createdAt char 建仓时间
updatedAt char 仓位变更时间

# 资金数据结构说明

Cash - 资金返回值字段

属性 类型 说明
accountId char 账号 ID
accountName char 账户登录名
currency double 币种
nav double 净值,总权益
pnl double 净收益
fpnl double 浮动盈亏
frozen double 持仓占用资金
orderFrozen double 挂单冻结资金
available double 可用资金
cumInout double 累计出入金
cumTrade double 累计交易额
cumPnl double 累计平仓收益(没扣除手续费)
cumCommission double 累计手续费
lastTrade double 上一次交易额
lastPnl double 上一次收益
lastCommission double 上一次手续费
lastInout double 上一次出入金
changeReason double 资金变更原因 取值参考 CashPositionChangeReason
changeEventId char 触发资金变更事件的 ID
createdAt char 资金初始时间
updatedAt char 资金变更时间

# order_volume按指定量委托

函数原型:

[ order] = order_volume( symbol, volume, side, order_type, position_effect, price, account)

参数说明

参数 类型 说明
symbols cell 下单标的
volume double 委托量,单位为:股票为股,期货为手
side double OrderSide 交易方向枚举类型
order_type double OrderType 交易类型枚举类型
position_effect double PositionEffect 开平仓枚举类型
account char 仿真和模拟可不填,实盘多账户填入账户的 ID
返回值 cell order 格式的订单信息

示例

[order]=order_volume('SZSE.000001', 100, OrderSide.OrderSide_Buy, OrderType.OrderType_Market,PositionEffect.PositionEffect_Open,0)

返回值

order =

  Columns 1 through 9

    'strategyId'    'accountId'    'accountName'    'clOrdId'      'orderId'    'exOrdId'    'symbol'         'side'    'positionEffect'
     [1x36 char]    [1x36 char]    ''               '000000001'    ''           ''           'SZSE.000001'    [   1]    [             1]

  Columns 10 through 17

    'positionSide'    'orderType'    'orderDuration'    'orderQualifier'    'orderSrc'    'status'    'ordRejReason'    'ordRejReasonDetail'
    [           1]    [        2]    [            0]    [             0]    [       0]    [     3]    [           0]    ''

  Columns 18 through 26

    'price'     'stopPrice'    'orderStyle'    'volume'    'value'       'percent'       'targetVolume'    'targetValue'    'targetPercent'
    [8.9800]    [        0]    [         1]    [   100]    [898.0000]    [8.9800e-04]    [         200]    [ 1.7960e+03]    [       0.0018]

  Columns 27 through 31

    'filledVolume'    'filledVwap'    'filledAmount'    'filledCommission'    'updatedAt'
    [         100]    [    8.9800]    [    898.0000]    [          0.8980]    '0001-01-01 00:00:00'

# order_value按指定价值委托

函数原型:

[ order]  = order_value (  symbol, value, side, order_type, position_effect,price, account )

参数说明

参数 类型 说明
symbols cell 下单标的
value double 委托资金量
side double OrderSide 交易方向枚举类型
order_type double OrderType 交易类型枚举类型
position_effect double PositionEffect 开平仓枚举类型
account char 仿真和模拟可不填,实盘多账户填入账户的 ID
返回值 cell order 格式的订单信息

示例

[order]=order_value('SZSE.000001', 10000, OrderSide.OrderSide_Buy, OrderType.OrderType_Market,PositionEffect.PositionEffect_Open,0)

# order_percent按总资产指定比例委托

函数原型:

[ order] = order_percent( symbol, percent, side, order_type,position_effect,price, account)

参数说明

参数 类型 说明
symbols cell 下单标的
percent double 委托占总资金的百分比
side double OrderSide 交易方向枚举类型
order_type double OrderType 交易类型枚举类型
position_effect double PositionEffect 开平仓枚举类型
account char 仿真和模拟可不填,实盘多账户填入账户的 ID
返回值 cell order 格式的订单信息

示例

[order]=order_percent('SZSE.000001', 0.1, OrderSide.OrderSide_Buy, OrderType.OrderType_Market,PositionEffect.PositionEffect_Open,0);

# order_target_volume调仓到目标持仓量

函数原型:

[ order] = order_target_volume( symbol, volume, side, order_type,price, account)

参数说明

参数 类型 说明
symbols cell 下单标的
volume double 目标持仓量,单位为:股票为股,期货为手
side double OrderSide 交易方向枚举类型
order_type double OrderType 交易类型枚举类型
position_effect double PositionEffect 开平仓枚举类型
account char 仿真和模拟可不填,实盘多账户填入账户的 ID
返回值 cell order 格式的订单信息

示例

[order]=order_target_volume('SZSE.000001', 10000, OrderSide.OrderSide_Buy, OrderType.OrderType_Market,0)

# order_target_value调仓到目标持仓额

函数原型:

[ order] =order_target_value( symbol, value, side, order_type,price, account)

参数说明

参数 类型 说明
symbols cell 下单标的
value double 目标持仓价值
side double OrderSide 交易方向枚举类型
order_type double OrderType 交易类型枚举类型
position_effect double PositionEffect 开平仓枚举类型
account char 仿真和模拟可不填,实盘多账户填入账户的 ID
返回值 cell order 格式的订单信息

示例

[order]=order_target_value('SZSE.000001', 10000, OrderSide.OrderSide_Buy, OrderType.OrderType_Market,0)

# order_target_percent调仓到目标持仓比例(总资产的比例)

函数原型:

[ order] = order_target_percent( symbol, percent, side, order_type,  price, account)

参数说明

参数 类型 说明
symbols cell 下单标的
percent double 目标总资产管比例
side double OrderSide 交易方向枚举类型
order_type double OrderType 交易类型枚举类型
position_effect double PositionEffect 开平仓枚举类型
account char 仿真和模拟可不填,实盘多账户填入账户的 ID

示例

[order]=order_target_percent('SZSE.000001', 0.5, OrderSide.OrderSide_Buy, OrderType.OrderType_Market,0)

# order_batch批量委托

相比循环下单,批量委托在下单流程上一次完成,延迟更低

函数原型:

[ orders ] = order_batch( order_cell)

参数说明 order_cell 是由以下参数组成的委托矩阵,

参数 类型 说明
symbols cell 下单标的
percent double 目标总资产管比例
side double OrderSide 交易方向枚举类型
order_type double OrderType 交易类型枚举类型
position_effect double PositionEffect 开平仓枚举类型
account char 仿真和模拟可不填,实盘多账户填入账户的 ID

示例

order_cell = {'SHSE.600000', 100, OrderSide.OrderSide_Buy, OrderType.OrderType_Limit,PositionEffect.PositionEffect_Open, 11;
              'SHSE.600004', 100, OrderSide.OrderSide_Buy, OrderType.OrderType_Limit,PositionEffect.PositionEffect_Open, 18};
[ orders ] = order_batch( order_cell);

# order_cancel撤销指定委托

函数原型

[ reg ] = order_cancel( clOrdIds, account)

说明:
clOrdIds 字段数据由订单数据中的 clOrdId 获取,返回结果为撤单成功或者失败

# order_cancel_all撤销所有委托

函数原型:

order_cancel_all()

# order_close_all平当前所有可平持仓

函数原型:

order_close_all()

# get_unfinished_orders查询日内全部未结委托

函数原型:

get_unfinished_orders()

说明:
返回 cell 格式的订单数据表

# get_orders查询日内全部委托

函数原型:

get_orders()

说明:
返回 cell 格式的订单数据列表

# get_execution_reports查询日内全部执行回报

函数原型:

get_execution_reports()

示例

[ excerpt ] = get_execution_reports(  )

返回值

excerpt =

  Columns 1 through 9

    'strategyId'    'accountId'    'accountName'    'clOrdId'      'orderId'    'execId'    'symbol'         'positionEffect'    'side'
     [1x36 char]    ''             ''               '000000341'    ''           ''          'SZSE.000001'    [             1]    [   1]
     [1x36 char]    ''             ''               '000000340'    ''           ''          'SZSE.000001'    [             1]    [   1]

  Columns 10 through 17

    'ordRejReason'    'ordRejReasonDetail'    'execType'    'price'     'volume'    'amount'        'commission'    'cost'
    [           0]    ''                      [      15]    [8.9800]    [  1100]    [9.8780e+03]    [         0]    [   0]
    [           0]    ''                      [      15]    [8.9800]    [  1100]    [9.8780e+03]    [         0]    [   0]

  Column 18

    'createdAt'
    '0001-01-01 00:00:00'
    '0001-01-01 00:00:00'

# get_position持仓查询

[ position ] = get_position( account )

示例:

[ position ] = get_position(  )

返回值

position =

  Columns 1 through 9

    'accountId'    'accountName'    'symbol'         'side'    'volume'    'volumeToday'    'vwap'      'amount'        'price'
    [1x36 char]    ''               'SZSE.000001'    [   1]    [  2200]    [       2200]    [8.9800]    [1.9756e+04]    [    0]

  Columns 10 through 17

    'fpnl'        'cost'          'orderFrozen'    'orderFrozenToday'    'available'    'available_today'    'lastPrice'    'lastVolume'
    [242.0013]    [1.9756e+04]    [          0]    [               0]    [     2200]    [           2200]    [        0]    [         0]

  Columns 18 through 22

    'lastInout'    'changeReason'    'hasDividend'    'createdAt'              'updatedAt'
    [        0]    [           0]    [          0]    '2018-08-06 09:45:00'    '2018-08-06 09:45:00'

# get_cash资金查询

[ cash] = get_cash( account )

示例

[ cash ] = get_cash(  )

返回值

position

  Columns 1 through 8

    'accountId'    'accountName'    'currency'    'nav'           'pnl'          'fpnl'        'frozen'        'orderFrozen'
    [1x36 char]    ''               [       0]    [9.9989e+05]    [-107.7559]    [-87.9999]    [1.9756e+04]    [          0]

  Columns 9 through 16

    'available'     'balance'    'cumInout'    'cumTrade'      'cumPnl'    'cumCommission'    'lastTrade'     'lastPnl'
    [9.8022e+05]    [      0]    [ 1000000]    [1.9756e+04]    [     0]    [      19.7560]    [9.8780e+03]    [      0]

  Columns 17 through 22

    'lastCommission'    'lastInout'    'changeReason'    'changeEventId'    'createdAt'              'updatedAt'
    [        9.8780]    [        0]    [           0]    ''                 '2018-08-05 10:40:00'    '2018-08-06 09:45:00'
上次更新: 1/5/2024, 3:37:58 PM