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

双均线策略示例

个股:中国平安

回测日期:2022-5-1至2023-5-1

短均线:5天

长无线:10天

代码:

python 复制代码
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天

java 复制代码
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

回测结果:

相关推荐
rufeike40 分钟前
Redis学习笔记
redis·笔记·学习
重庆小透明3 小时前
【从零开始学习JVM | 第六篇】运行时数据区
java·jvm·后端·学习
晨曦backend4 小时前
Vim 替换命令完整学习笔记
笔记·学习·vim
liuyang___5 小时前
日期的数据格式转换
前端·后端·学习·node.js·node
蒙奇D索大5 小时前
【11408学习记录】[特殊字符] 速解命题核心!考研数学线性代数:4类行列式满分技巧(含秒杀公式)
笔记·学习·线性代数·考研·改行学it
江池俊6 小时前
通过Docker和内网穿透技术在Linux上搭建远程Logseq笔记系统
linux·笔记·docker
哆啦A梦的口袋呀6 小时前
基于Python学习《Head First设计模式》第十章 状态模式
学习·设计模式
moxiaoran57536 小时前
uni-app学习笔记三十六--分段式选项卡组件的使用
笔记·学习·uni-app
笑鸿的学习笔记6 小时前
Windows笔记之Win11让非焦点窗口程序也能获得流畅性能的方法
windows·笔记
栗子不爱栗子7 小时前
从理解AI到驾驭文字:一位技术爱好者的写作工具探索手记
python·学习·ai