# coding=utf-8

from __future__ import print_function, absolute_import, unicode_literals

import numpy as np

import pandas as pd

from gm.api import *

'''

本策略标的为:SHFE.rb1901

价格中枢设定为:前一交易日的收盘价

从阻力位到压力位分别为:1.03 * open、1.02 * open、1.01 * open、open、0.99 * open、0.98 * open、0.97 * open

每变动一个网格,交易量变化100个单位

回测数据为:SHFE.rb1901的1min数据

回测时间为:2017-07-01 08:00:00到2017-10-01 16:00:00

'''

def init(context):

# 策略标的为SHFE.rb1901

context.symbol = 'SHFE.rb1901'

# 订阅SHFE.rb1901, bar频率为1min

subscribe(symbols = context.symbol, frequency='60s')

# 设置每变动一格,增减的数量

context.volume = 1

# 储存前一个网格所处区间,用来和最新网格所处区间作比较

context.last_grid = 0

# 以前一日的收盘价为中枢价格

context.center = history_n(symbol= context.symbol,frequency='1d',end_time=context.now,count = 1,fields = 'close')[0]['close']

# 记录上一次交易时网格范围的变化情况(例如从4区到5区,记为4,5)

context.grid_change_last = [0,0]

def on_bar(context, bars):

bar = bars[0]

# 获取多仓仓位

position_long = context.account().position(symbol=context.symbol, side=PositionSide_Long)

# 获取空仓仓位

position_short = context.account().position(symbol=context.symbol, side=PositionSide_Short)

# 设置网格和当前价格所处的网格区域

context.band = np.array([0.97, 0.98, 0.99, 1, 1.01, 1.02, 1.03]) * context.center

grid = pd.cut([bar.close], context.band, labels=[1, 2, 3, 4, 5, 6])[0]

# 如果价格超出网格设置范围,则提示调节网格宽度和数量

if np.isnan(grid):

print('价格波动超过网格范围,可适当调节网格宽度和数量')

# 如果新的价格所处网格区间和前一个价格所处的网格区间不同,说明触碰到了网格线,需要进行交易

# 如果新网格大于前一天的网格,做空或平多

if context.last_grid < grid:

# 记录新旧格子范围(按照大小排序)

grid_change_new = [context.last_grid,grid]

# 几种例外:

# 当last_grid = 0 时是初始阶段,不构成信号

# 如果此时grid = 3,说明当前价格仅在开盘价之下的3区域中,没有突破网格线

# 如果此时grid = 4,说明当前价格仅在开盘价之上的4区域中,没有突破网格线

if context.last_grid == 0:

context.last_grid = grid

return

if context.last_grid != 0:

# 如果前一次开仓是4-5,这一次是5-4,算是没有突破,不成交

if grid_change_new != context.grid_change_last:

# 更新前一次的数据

context.last_grid = grid

context.grid_change_last = grid_change_new

# 如果有多仓,平多

if position_long:

order_volume(symbol=context.symbol, volume=context.volume, side=OrderSide_Sell, order_type=OrderType_Market,

position_effect=PositionEffect_Close)

print('以市价单平多仓{}手'.format(context.volume))

# 否则,做空

if not position_long:

order_volume(symbol=context.symbol, volume=context.volume, side=OrderSide_Sell, order_type=OrderType_Market,

position_effect=PositionEffect_Open)

print('以市价单开空{}手'.format(context.volume))

# 如果新网格小于前一天的网格,做多或平空

if context.last_grid > grid:

# 记录新旧格子范围(按照大小排序)

grid_change_new = [grid,context.last_grid]

# 几种例外:

# 当last_grid = 0 时是初始阶段,不构成信号

# 如果此时grid = 3,说明当前价格仅在开盘价之下的3区域中,没有突破网格线

# 如果此时grid = 4,说明当前价格仅在开盘价之上的4区域中,没有突破网格线

if context.last_grid == 0:

context.last_grid = grid

return

if context.last_grid != 0:

# 如果前一次开仓是4-5,这一次是5-4,算是没有突破,不成交

if grid_change_new != context.grid_change_last:

# 更新前一次的数据

context.last_grid = grid

context.grid_change_last = grid_change_new

# 如果有空仓,平空

if position_short:

order_volume(symbol=context.symbol, volume=context.volume, side=OrderSide_Buy,

order_type=OrderType_Market,

position_effect=PositionEffect_Close)

print('以市价单平空仓{}手'.format(context.volume))

# 否则,做多

if not position_short:

order_volume(symbol=context.symbol, volume=context.volume, side=OrderSide_Buy,

order_type=OrderType_Market,

position_effect=PositionEffect_Open)

print('以市价单开多{}手'.format(context.volume))

# 设计一个止损条件:当持仓量达到10手,全部平仓

if position_short == 10 or position_long == 10:

order_close_all()

print('触发止损,全部平仓')

if __name__ == '__main__':

'''

strategy_id策略ID,由系统生成

filename文件名,请与本文件名保持一致

mode实时模式:MODE_LIVE回测模式:MODE_BACKTEST

token绑定计算机的ID,可在系统设置-密钥管理中生成

backtest_start_time回测开始时间

backtest_end_time回测结束时间

backtest_adjust股票复权方式不复权:ADJUST_NONE前复权:ADJUST_PREV后复权:ADJUST_POST

backtest_initial_cash回测初始资金

backtest_commission_ratio回测佣金比例

backtest_slippage_ratio回测滑点比例

'''

run(strategy_id='strategy_id',

filename='main.py',

mode=MODE_BACKTEST,

token='token_id',

backtest_start_time='2018-07-01 08:00:00',

backtest_end_time='2018-10-01 16:00:00',

backtest_adjust=ADJUST_PREV,

backtest_initial_cash=100000,

backtest_commission_ratio=0.0001,

backtest_slippage_ratio=0.0001)

网格交易 python代码_网格交易原理和代码相关推荐

  1. 量化交易python入门书籍_量化交易新手最适用的5本书

    交易知识就在 -- ALPHA ZONE-HOME ,由自营交易室机构交易员主导,理论结合实践,助力金融知识变现! 算法交易通常是一个被初学者认为很难掌握的复杂领域.它涵盖了广泛的学科,某些方面需要相 ...

  2. python 网格交易源码_网格交易策略(难度:中级)

    什么是网格交易策略 网格交易又名渔网交易,就是跌买涨卖.它适合震荡市,震荡市就是行情价围着一个数字上下浮动的,这个数字就是设置的价格中轴线. 设定中枢价格后,对投资标的进行机械式操作,下跌时,进行分档 ...

  3. python历史性分布计算代码_量化交易中,如何使用Python计算「筹码分布」指标【附代码】 [量化小讲堂-64]...

    引言: 邢不行的系列帖子"量化小讲堂",通过实际案例教初学者使用python进行量化投资,了解行业研究方向,希望能对大家有帮助. [历史文章汇总] 请点击此处 这是邢不行第  64 ...

  4. python期货程序化交易高手心得_程序化交易高手的交易心得 分享~

    总体来说, 一.行情研判模块 行情研判模块是主要为资金管理和交易策略服务的.如果除去这一点,所有的行情研判就都失去了目标也就没有办法设立标准,当然也就没有了实际的意义.预测是研判的一部分,但是研判不仅 ...

  5. python测验5 函数和代码_测验5: 函数和代码复用 (第5周)-单选题

    1.以下选项不是函数作用的是:‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬ A. 提 ...

  6. java测试性能代码_关于性能:Java代码内部的基准测试

    我最近一直在研究基准测试,我一直对记录程序数据等感兴趣.我想知道我们是否可以在程序中有效地实现自己的内存使用代码和实现自己的时间消耗代码.我知道如何检查代码运行所需的时间: public static ...

  7. 一段堆栈溢出的代码_为什么堆栈溢出的代码片段会破坏您的项目

    一段堆栈溢出的代码 Stack Overflow has been the saviour of many programmers, including me. Some of us have nev ...

  8. 史上最烂代码_历史上最大的代码库

    史上最烂代码 Here's a diagram of the biggest codebases in history, as measured by lines of code: 这是历史上最大的代 ...

  9. idea看更改过的代码_就是你把所有代码全写在一个类里的?

    来源 | https://urlify.cn/6jQRN3 最近,在对已有项目进行扩展的时候,发现要改动的一个类它长900行,开放了近40个public接口,我流着泪把它给改完了. 为了防止这样的惨剧 ...

  10. vscode中怎样格式化js代码_如何在Visual Studio代码(VSCode)中格式化代码

    回答(30) 2 years ago 对于那些想要自定义要格式化的JavaScript文件的人,可以使用 JSfiles 属性上的任何扩展名同样适用于HTML . { "beautify.o ...

最新文章

  1. AI手语主播通过朱广权魔鬼面试,残影级手速无惧贯口,今已正式上岗助力冰雪盛会...
  2. JDBC操作之连接和关闭mysql数据库
  3. linux存储--虚拟内存详解MMU、页表(十)
  4. [导入]连连看.NET 1.41全部源码
  5. 用神经网络模拟分子:数据精确性检测
  6. c语言输入三个数判断等边三角形,随便输入三个数,看能否组成一个三角形
  7. 查询计算机端口号被谁占用了
  8. Codeforces Round #285 (Div. 2) D. Misha and Permutations Summation 康托展开 + 线段树
  9. 2017.10.31笔记
  10. shell之for循环的3个简单脚本
  11. Oracle的共享关闭 独有关闭和共享更新关闭 (2)
  12. 三层交换机/路由器OSPF配置详解【华为eNSP实验】
  13. 会员直推奖php程序_PHP自适应卡益源码 前台直销系统报单费直推奖
  14. 用keytool生成证书
  15. 用STEP7-MicroWIN SMART能搜索到CPU 也能控制PLC指示灯闪烁,但是下载程序仍提示当前IP地址失败请检查IP地址、网络连接
  16. [论文翻译]Reducing the Dimensionality of Data with Neural Networks
  17. PMP模拟试题与解析(四)
  18. MySQL基础篇 | 连接查询、子查询(嵌套)
  19. 九龙证券|次新股叠加智慧交通+信创+数字经济概念,开盘冲涨停!
  20. 三极管专题:PNP和NPN 三极管恒流电路分析

热门文章

  1. 笔记本电脑硬盘不见了_笔记本电脑找不到硬盘原因及解决方法
  2. 为企业出海“搭桥”,汇量科技靠什么出圈?
  3. wamp环境变量配置php,WAMP环境配置-PHP安装
  4. 计算机键盘重复,win7系统电脑键盘打字时总是出现重复字符的解决方法
  5. push to origin/dev was rejected
  6. 2021年煤气考试内容及煤气找解析
  7. URLDownloadToFile缓存问题
  8. 【笔记】STM32F4xx 时钟定时器
  9. 三星typec转接耳机没反应_typec转3.5mm转接线,你买对了吗?
  10. 用python制作一张简单的节日贺卡