量化交易实战【1】自己搭建一个的股票交易回测框架,并通过均线择时策略进行回测

简介: 量化交易实战【1】自己搭建一个的股票交易回测框架,并通过均线择时策略进行回测

前言


本文介绍了一个股票交易的基础回测框架,并且通过均线择时策略,详细的演示了策略搭建的过程,和大家共同学习交流。


  1. 文章示例中使用的‘000001.XSHE.csv’文件,已上传至csdn资源中,可直接下载


  1. 或者关注文末公众号:‘阿旭算法与机器学习’。然后输入:股票数据,即可获取4000多只股票从2015年1月至2022年10月的所有基础数据


1. 导入数据


import pandas as pd
import matplotlib.pyplot as plt


pd.set_option('display.max_columns', None) # 展示所有列
# 000001.XSHE.csv文件包含2015年1月至2022年10月的开盘价、收盘价、最高价、最低价、成交量、成交金额股票的基本数据
df = pd.read_csv('./000001.XSHE.csv')  
df.head()

image.png


# 求该股票每日涨跌幅
df['change_pct'] = df['close'].pct_change()
df = df[['date','open','close','high','low','change_pct']]
df['date'] = pd.to_datetime(df['date'])  # 将交易日期字符串变为日期类型
df.head()


image.png


2. 交易框架搭建–以均线策略为例


当短期均线由下向上穿过长期均线的时候,第二天以开盘价全仓买入并在之后一直持有;


当短期均线由上向下穿过长期均线的时候,第二天以开盘价全仓卖出,之后空仓,直到下次买入


2.1 计算均线数值


此处以短期均线MA=5;长期均线MA=20为例进行说明,至于参数的优化,需要依据不同股票的实际情况修改


# 计算均线
ma_short = 5  #短期均线,ma代表:moving_average
ma_long = 20  #长期均线,ma代表:moving_average
df['ma_short'] = df['close'].rolling(ma_short).mean()
df['ma_long'] = df['close'].rolling(ma_long).mean()
df.head(10)


image.png


#补全上面均线缺失值:补全方式采用扩展窗口函数expanding,移动计算前面所有值之和的均值
df['ma_short'].fillna(value=df['close'].expanding().mean(),inplace=True)
df['ma_long'].fillna(value=df['close'].expanding().mean(),inplace=True)
df.head(10)


image.png


2.2 产生交易信号:即找出买入与卖出信号


# 找买入信号
# 当天的短期均线大于等于长期均线
condition1 = (df['ma_short'] >= df['ma_long'])
# 上一个交易日的短期均线小于长期均线
condition2 = (df['ma_short'].shift(1) < df['ma_long'].shift(1))
# 将买入信号当天的signal设为1
df.loc[condition1 & condition2, 'signal'] = 1
# 找卖出信号
# 当天的短期均线小于等于长期均线
condition1 = (df['ma_short'] <= df['ma_long'])
# 上一个交易日的短期均线大于长期均线
condition2 = (df['ma_short'].shift(1) > df['ma_long'].shift(1))
# 将买入信号当天的signal设为0
df.loc[condition1 & condition2,'signal'] = 0
# 浏览产生交易信号的日期
df[df['signal'].notnull()].head(10)

image.png


2.3 由交易信号计算每天股票仓位


我们用1表示满仓,0表示空仓。当出现买入信号之后,全仓买入,当出现卖出信号之后,全仓卖出。


因此,当交易信号signal为1时,第二天仓位position也会变为1,之后的仓位一直为1,直到出现卖出信号,仓位变为0。


注意:此处因为signal的计算运用了收盘价,是每天收盘之后产生的信号,所以仓位position在第二天才会发生改变。

例如2015-05-01产生买入信号,2015-05-02仓位才会变成1,满仓用1表示,空仓用0表示

将signal信号下移一格,表示第二天买入,用1表示满仓,0表示空仓


# 新建列Pos表示仓位,将交易信号下移一格,表示第二天买入,1表示满仓,0表示空仓
df['pos'] = df['signal'].shift()
# 向上填充,将买入之后的pos全部设置为1
df['pos'].fillna(method='ffill', inplace=True)
# 没有买入的pos全部设置为0
df['pos'].fillna(value=0,inplace=True)
# 预览仓位数据
df[(df['date']>='2015-02-24')&(df['date']<'2015-05-06')][['date','signal','pos']].head(20)


image.png


2.4 排除当天开盘就涨跌停导致无法交易的情况,此时仓位不能改变


注意:开盘涨跌停,是基本无法买入或者卖出股票的。


# 找出开盘涨停的日期:即今天的开盘价相对于昨天的收盘价上涨了9.7%以上,此处不用10%是因为由于4舍5入,涨停不一定就是10%
cond_cannot_buy = df['open'] > df['close'].shift(1) * 1.097
# 将开盘涨停且当前position为1时的'pos'设为空值
df.loc[cond_cannot_buy & (df['pos'] == 1),'pos'] = None
# 找出开盘跌停的日期,即今天的开盘价相对于昨天的收盘价跌了9.7%(1-0.097=0.903)
cond_cannot_sell = df['open'] < df['close'].shift(1) *0.903
# 将开盘跌停且当前position为0时的'pos'设为空值
df.loc[cond_cannot_sell & (df['pos'] == 0),'pos'] = None
# position为空的日期表示不能买卖。position仓位只能和前一个交易日保持一致
df['pos'].fillna(method='ffill', inplace=True)


2.5 计算资金曲线并绘图


# 资金曲线:假设起始资金为100万元的每天资金变化情况
# 首先计算资金曲线每天的涨跌幅,‘equity_change’表示资金每天的涨跌幅
# 当天空仓时,pos为0,资产涨幅为0
# 当天满仓时,pos为1,资产涨幅为股票本身的涨跌幅
df['equity_change'] = df['change_pct'] * df['pos']
# 根据每天的涨跌幅计算资金曲线
df['equity_curve'] = 1000000 * (df['equity_change'] + 1).cumprod()
df = df[['date' , 'change_pct','pos','equity_change','equity_curve']]
df.reset_index(inplace=True, drop=True)  # 重置索引,让他从0开始
df.head(10)


image.png


# 绘制资金曲线
plt.plot(df['equity_curve'])
plt.show()

b7ead3d7595a4976909feb112761e574.png


通过资金曲线我们可以看到,该只股票从2015年1月开始至今,通过该策略最高是1.8倍收益,后面又跌回去了…


当然这个策略只是在此处搭建框架做演示用的,实际策略参数等都需要根据具体情况进行调整。


3. 总结


本文详细的介绍了通过股票数据及均线策略构建股票回测框架的过程:


  1. 导入数据,计算涨跌幅


  1. 通过均线策略产生交易信号


  1. 通过交易信号计算每天仓位


  1. 排除涨跌停无法进行交易的情况


  1. 通过仓位计算每天资金曲线,回测


对于其他择时交易策略,我们只需更改上述框架中的交易信号产生部分,就可以实现回测啦。


后续待改进的地方,本文在计算资金曲线的过程中,没有考虑交易手续费,买入时的价格与当天涨幅不匹配(当天开盘价买入,资金涨幅与当天股票涨幅不是同等的)等问题,下期会写一个实际操作过程中的资金曲线,将这些问题包含进去。如果有不对的地方,欢迎提出来共同学习交流,谢谢!

如果内容对你有帮助,记得点赞、关注哦!也欢迎小伙伴们和我共同学习交流。


更多干货内容持续更新中…


相关文章
|
6月前
|
算法 数据挖掘
【视频】量化交易陷阱和R语言改进股票配对交易策略分析中国股市投资组合
【视频】量化交易陷阱和R语言改进股票配对交易策略分析中国股市投资组合
|
Python
『三分钟学分析』Graveyard分析模型是真的牛X!(上)
在上篇品牌知名度实例的基础上,讲一个经典分析模型,对品牌知名度做更立体的分析。
605 0
『三分钟学分析』Graveyard分析模型是真的牛X!(上)
|
2月前
|
机器学习/深度学习 数据采集 TensorFlow
使用Python实现智能股票交易策略
使用Python实现智能股票交易策略
71 0
|
6月前
|
数据可视化 Python
R语言无套利区间模型期货期现研究:正向套利和反向套利次数、收益率分析华泰柏瑞300ETF可视化
R语言无套利区间模型期货期现研究:正向套利和反向套利次数、收益率分析华泰柏瑞300ETF可视化
|
6月前
|
数据可视化 Python
R语言量化技术分析的百度指数关注度交易策略可视化
R语言量化技术分析的百度指数关注度交易策略可视化
|
6月前
R语言金融市场量化交易:布林带、价差策略、RSI交易策略,回测COMP 226
R语言金融市场量化交易:布林带、价差策略、RSI交易策略,回测COMP 226
|
6月前
|
Python
python实现股票策略回测案例
此Python代码演示了一个简单的股票策略回测,使用yfinance库获取AAPL股票2020年至2022年的数据。它计算每日收益率,并基于前一日收益率决定买卖:正则买入,负则卖出。通过模拟交易更新现金和股票余额,最终计算总收益。请注意,此示例未涵盖交易费用、滑点、风险管理等实际交易因素。
174 0
|
6月前
|
机器学习/深度学习 供应链 算法
Python配对交易策略统计套利量化交易分析股票市场
Python配对交易策略统计套利量化交易分析股票市场
|
6月前
|
Perl
R语言回测交易:根据历史信号/交易创建股票收益曲线
R语言回测交易:根据历史信号/交易创建股票收益曲线
|
6月前
r语言多均线股票价格量化策略回测
r语言多均线股票价格量化策略回测
下一篇
无影云桌面