逐次漸進:pythonで金融量子化分析(五)MACD戦略システムを行う
1609 ワード
このセクションでは、ライブラリimport talibを導入します.このライブラリには多くの技術指標があるので、直接参照することができ、自分で指標関数を編集する必要がなく、非常に便利です.macd、macdsignal、macdhist=talibであれば、MACD(ma,fastperiod=12,slowperiod=26,signalperiod=9)は直接MACDデータを返すことができ、その他の面では、均線システムのプログラムを少し修正すれば適用できます.プログラムは以下の通りです.
import pandas as pd
import xlrd
import matplotlib.pyplot as plt
import numpy as np
import talib
xls = xlrd.open_workbook('hs300.xls')#
sheet = xls.sheets()[0]# 1
col = sheet.col_values(0)#
nrows = sheet.nrows #
ma_re = pd.DataFrame(columns=['ret','max_re','min_re','win_rate','winloss_rate'])
ma=np.array(col)
macd, macdsignal, macdhist = talib.MACD(ma, fastperiod=12, slowperiod=26, signalperiod=9) # talib MACD
buy=[]
sell=[]
ret=0
a=0 # ,0
s=0 #
win=0 #
loss=0 #
row=0
for k in range(31,nrows):
if macdhist[k]>0 and a==0: # ,
# if macdhist[k]>0 and a==0:
buy.append(col[k])
a=1
elif macdhist[k]<0 and a==1: # ,
sell.append(col[k])
a=0
for l in range(0,len(sell)): # ,
ret += sell[l]-buy[l]
sb=sell[l]-buy[l]
if sb>0:
s+=1
win+=sb
else:
loss+=sb
re=[sell[i]-buy[i] for i in range(len(sell))] #
max_re=max(re)
min_re=min(re)
if s==len(sell):
winloss_rate=win
elif (s==0.0):
winloss_rate=0
else:
winloss_rate=(win/s)/(abs(loss)/(len(sell)-s))
win_rate=s/len(sell)
ma_re.loc[row] = [ret,max_re,min_re,win_rate,winloss_rate] #
row+=1
print(ma_re)