• QQ空间
  • 回复
  • 收藏

【宽客策略源码】日内回转交易(股票)

geek168 数据策略 2019-8-11 15:55 101179人围观


本策略首先买入SHSE.600000股票10000股,随后根据60s的数据来计算MACD(12,26,9)线,并在MACD>0的时候买入100股,MACD<0的时候卖出100股
,但每日操作的股票数不超过原有仓位,并于收盘前把仓位调整至开盘前的仓位

回测数据为:SHSE.600000的60s数据
回测时间为:2017-09-01 08:00:00到2017-10-01 16:00:00


  1. # coding=utf-8
  2. from __future__ import print_function, absolute_import, unicode_literals
  3. try:
  4.     import talib
  5. except:
  6.     print('请安装TA-Lib库')
  7. from gm.api import *

  8. def init(context):
  9.     # 设置标的股票
  10.     context.symbol = 'SHSE.600000'
  11.     # 用于判定第一个仓位是否成功开仓
  12.     context.first = 0
  13.     # 订阅浦发银行, bar频率为1min
  14.     subscribe(symbols=context.symbol, frequency='60s', count=35)
  15.     # 日内回转每次交易100股
  16.     context.trade_n = 100
  17.     # 获取昨今天的时间
  18.     context.day = [0, 0]
  19.     # 用于判断是否触发了回转逻辑的计时
  20.     context.ending = 0
  21. def on_bar(context, bars):
  22.     bar = bars[0]
  23.     if context.first == 0:
  24.         # 最开始配置仓位
  25.         # 需要保持的总仓位
  26.         context.total = 10000
  27.         # 购买10000股浦发银行股票
  28.         order_volume(symbol=context.symbol, volume=context.total, side=PositionSide_Long,
  29.                      order_type=OrderType_Market, position_effect=PositionEffect_Open)
  30.         print(context.symbol, '以市价单开多仓10000股')
  31.         context.first = 1.
  32.         day = bar.bob.strftime('%Y-%m-%d')
  33.         context.day[-1] = day[-2:]
  34.         # 每天的仓位操作
  35.         context.turnaround = [0, 0]
  36.         return
  37.     # 更新最新的日期
  38.     day = bar.bob.strftime('%Y-%m-%d %H:%M:%S')
  39.     context.day[0] = bar.bob.day
  40.     # 若为新的一天,获取可用于回转的昨仓
  41.     if context.day[0] != context.day[-1]:
  42.         context.ending = 0
  43.         context.turnaround = [0, 0]
  44.     if context.ending == 1:
  45.         return
  46.     # 若有可用的昨仓则操作
  47.     if context.total >= 0:
  48.         # 获取时间序列数据
  49.         symbol = bar['symbol']
  50.         recent_data = context.data(symbol=symbol, frequency='60s', count=35, fields='close')
  51.         # 计算MACD线
  52.         macd = talib.MACD(recent_data['close'].values)[0][-1]
  53.         # 根据MACD>0则开仓,小于0则平仓
  54.         if macd > 0:
  55.             # 多空单向操作都不能超过昨仓位,否则最后无法调回原仓位
  56.             if context.turnaround[0] + context.trade_n < context.total:
  57.                 # 计算累计仓位
  58.                 context.turnaround[0] += context.trade_n
  59.                 order_volume(symbol=context.symbol, volume=context.trade_n, side=PositionSide_Long,
  60.                              order_type=OrderType_Market, position_effect=PositionEffect_Open)
  61.                 print(symbol, '市价单开多仓', context.trade_n, '股')
  62.         elif macd < 0:
  63.             if context.turnaround[1] + context.trade_n < context.total:
  64.                 context.turnaround[1] += context.trade_n
  65.                 order_volume(symbol=context.symbol, volume=context.trade_n, side=PositionSide_Short,
  66.                              order_type=OrderType_Market, position_effect=PositionEffect_Close)
  67.                 print(symbol, '市价单平多仓', context.trade_n, '股')
  68.         # 临近收盘时若仓位数不等于昨仓则回转所有仓位
  69.         if day[11:16] == '14:55' or day[11:16] == '14:57':
  70.             position = context.account().position(symbol=context.symbol, side=PositionSide_Long)
  71.             if position['volume'] != context.total:
  72.                 order_target_volume(symbol=context.symbol, volume=context.total, order_type=OrderType_Market,
  73.                                     position_side=PositionSide_Long)
  74.                 print('市价单回转仓位操作...')
  75.                 context.ending = 1
  76.         # 更新过去的日期数据
  77.         context.day[-1] = context.day[0]
  78. if __name__ == '__main__':
  79.     '''
  80.     strategy_id策略ID,由系统生成
  81.     filename文件名,请与本文件名保持一致
  82.     mode实时模式:MODE_LIVE回测模式:MODE_BACKTEST
  83.     token绑定计算机的ID,可在系统设置-密钥管理中生成
  84.     backtest_start_time回测开始时间
  85.     backtest_end_time回测结束时间
  86.     backtest_adjust股票复权方式不复权:ADJUST_NONE前复权:ADJUST_PREV后复权:ADJUST_POST
  87.     backtest_initial_cash回测初始资金
  88.     backtest_commission_ratio回测佣金比例
  89.     backtest_slippage_ratio回测滑点比例
  90.     '''
  91.     run(strategy_id='strategy_id',
  92.         filename='main.py',
  93.         mode=MODE_BACKTEST,
  94.         token='token_id',
  95.         backtest_start_time='2017-09-01 08:00:00',
  96.         backtest_end_time='2017-10-01 16:00:00',
  97.         backtest_adjust=ADJUST_PREV,
  98.         backtest_initial_cash=2000000,
  99.         backtest_commission_ratio=0.0001,
  100.         backtest_slippage_ratio=0.0001)
复制代码

日内回转.png


路过

雷人

握手

鲜花

鸡蛋
原作者: abctrader
关注微信