AKSHARE 上获取股票数据用于盘后分析以及自己的交易模型的测试。

TUSHARE 不太好用 改成AKSHARE 以后感觉还行。对应的数据获取   根据AKSHARE的文档进行

import pandas as pd
import matplotlib.pyplot as plt
import mplfinance as mpf
import talib
import akshare as ak
# AKSHARE上获取数据  从某天到某天后复权
stock_zh_a_daily_hfq_d = ak.stock_zh_a_daily(symbol="sz000002", start_date="20150101", end_date="20200101", adjust="hfq")

# 获取SZ000002从20150101 to 20200101  后复权
df = stock_zh_a_daily_hfq_d.iloc[:, 0:6]
df.reset_index(inplace = True) 
df['date'] = pd.to_datetime(df['date'],format='%Y-%m-%d')

print(df)
df.set_index('date',inplace=True)
df.rename(columns = {0:"Date"}) 

# mpf.plot(df, type='candle')

my_color = mpf.make_marketcolors(up='red',#上涨时为红色
                                 down='green',#下跌时为绿色
                                 edge='i',#隐藏k线边缘
                                 volume='in',#成交量用同样的颜色
                                 inherit=True)

my_style = mpf.make_mpf_style(gridaxis='both',#设置网格
                           gridstyle='-.',
                           y_on_right=True,
                            marketcolors=my_color)

#计算OBV
df['OBV'] = talib.OBV(df.close,df.volume)
#计算布林带上中下轨
#matype=talib.MA_Type.T3表示用指数移动平均的方法进行平均
df['upper'],df['middle'],df['lower'] = talib.BBANDS(df.close, matype=talib.MA_Type.T3)
#设置要显示的信息
add_plot = [mpf.make_addplot(df[['upper','lower']],linestyle='dashdot'),
            mpf.make_addplot(df['middle'],linestyle='dotted',color='y'),
            mpf.make_addplot(df['OBV'],panel='lower',color='b')]#panel为lower表示在附图中显示


mpf.plot(df,type='candle',
         style=my_style,
         addplot=add_plot,
         volume=True,#展示成交量副图
         figratio=(2,1),#设置图片大小
         figscale=5)   
 

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值