当前位置: 首页 > article >正文

量化交易学习笔记02:双均线策略

双均线策略示例

个股:中国平安
回测日期:2022-5-1至2023-5-1
短均线:5天
长无线:10天
代码:

def initialize(context):
    # 初始化此策略
    # 设置我们要操作的股票池, 这里我们只操作一支股票
    # """标的"""
    g.security = '601318.SS'
    set_universe(g.security)
    
#当五日均线高于十日均线时买入,当五日均线低于十日均线时卖出
def handle_data(context, data):
    security = g.security

    #得到二十日历史价格
    df = get_history(20, '1d', 'close', security, fq=None, include=False)
    #"""指标"""
    # 得到五日均线价格
    ma5 = round(df['close'][-5:].mean(), 3)
    ma5_prev = round(df['close'][-6:-1].mean(), 3)
    # 得到十日均线价格
    ma10 = round(df['close'][-10:].mean(), 3)
    ma10_prev = round(df['close'][-11:-1].mean(), 3)
    # 取得昨天收盘价
    price = data[security]['close']

    # 得到当前资金余额
    cash = context.portfolio.cash
    
    #"""择时"""
    # 如果当前有余额,并且五日均线大于十日均线
    if ma5 > ma10 and ma5_prev < ma10_prev:
        # 用所有 cash 买入股票
        order_value(security, cash)
        # 记录这次买入
        log.info("Buying %s" % (security))
            
    # 如果五日均线小于十日均线,并且目前有头寸
    elif ma5 < ma10 and ma5_prev > ma10_prev :
        # 全部卖出
        order_target(security, 0)
        # 记录这次卖出
        log.info("Selling %s" % (security))

def control_risk(context):
    #"""风控"""
    pass

ptrader测试结果:
在这里插入图片描述

修改两条均线日期后

个股:中国平安
回测日期:2022-5-1至2023-5-1
短均线:10天
长无线:15天

def initialize(context):
    # 初始化此策略
    # 设置我们要操作的股票池, 这里我们只操作一支股票
    # """标的"""
    g.security = '601318.SS'
    set_universe(g.security)
    
#当五日均线高于十日均线时买入,当五日均线低于十日均线时卖出
def handle_data(context, data):
    security = g.security

    #得到二十日历史价格
    df = get_history(20, '1d', 'close', security, fq=None, include=False)
    #"""指标"""
    # 得到十日日均线价格
    ma5 = round(df['close'][-10:].mean(), 3)
    ma5_prev = round(df['close'][-11:-1].mean(), 3)
    # 得到十五日均线价格
    ma10 = round(df['close'][-15:].mean(), 3)
    ma10_prev = round(df['close'][-16:-1].mean(), 3)
    # 取得昨天收盘价
    price = data[security]['close']

    # 得到当前资金余额
    cash = context.portfolio.cash
    
    #"""择时"""
    # 如果当前有余额,并且五日均线大于十日均线
    if ma5 > ma10 and ma5_prev < ma10_prev:
        # 用所有 cash 买入股票
        order_value(security, cash)
        # 记录这次买入
        log.info("Buying %s" % (security))
            
    # 如果五日均线小于十日均线,并且目前有头寸
    elif ma5 < ma10 and ma5_prev > ma10_prev :
        # 全部卖出
        order_target(security, 0)
        # 记录这次卖出
        log.info("Selling %s" % (security))

def control_risk(context):
    #"""风控"""
    pass

回测结果:
在这里插入图片描述


http://www.kler.cn/a/588338.html

相关文章:

  • java项目之基于ssm的药店药品信息管理系统(源码+文档)
  • TCP/IP协议中三次握手(Three-way Handshake)与四次挥手(Four-way Wave)
  • 面试系列|蚂蚁金服技术面【1】
  • C++那些事儿:访问控制与友元函数的奇妙冒险
  • C语言 —— 此去经年梦浪荡魂音 - 深入理解指针(卷一)
  • Vue开发者工具(VueDevtools)下载与安装
  • 区跨链知识和概念
  • C++|空指针nullptr
  • Ubuntu24.10编译Android12源码并运行于模拟器中
  • How To Change Windows VPS Password
  • LeetCodeHot100_0x07
  • [蓝桥杯 2023 省 A] 买瓜 --暴力DFS+剪枝优化
  • 深入分析 Shell 中 IFS、数组赋值与输出行为
  • 相对论-空间和时间(1)
  • ngx_event_conf_t
  • 淘宝API vs 爬虫:合规获取实时商品数据的成本与效率对比
  • [论文阅读]Demystifying Prompts in Language Models via Perplexity Estimation
  • 前端性能优化指标及优化方案
  • Leetcode-1278.Palindrome Partitioning IV [C++][Java]
  • 重返OI:1999