用tushare和mplfinance画K线图

阅读: 评论:0

用tushare和mplfinance画K线图

用tushare和mplfinance画K线图

导入 tushare并连接API获取股票数据

import tushare as ts
ts.set_token('Your token')
pro = ts.pro_api()
df= pro.daily(ts_code='600809.SH', start_date='20220401', end_date='20220701')

导入需要的包

import pandas as pd
import numpy as np
import mplfinance as mpf
import matplotlib.pyplot as plt
import talib
from matplotlib.dates import DateFormatter, WeekdayLocator, DayLocator, MONDAY,YEARLY
df1=df

 mplfinance对数据格式有要求需做一定的处理


def getData(df):df=pd.DataFrame(ame(columns={'trade_date':'Date','open':'Open','high':'High','low':'Low','close':'Close','vol':'Volume'},inplace=True)df=df[['Date','Open','High','Low','Close','Volume']]df['Date']&#_datetime(df['Date'])df.set_index(['Date'],inplace=True)df=df.sort_index()return df
df=getData(df)

 设置自己的绘画风格

#设置绘画风格
mystyle = dict(style_name    = 'style',base_mpl_style= 'fast', marketcolors  = {'candle'  : {'up':'w', 'down':'g'}, #填充颜色'edge'    : {'up':'r', 'down':'g'}, #边缘颜色'wick'    : {'up':'r', 'down':'g'}, #灯芯颜色'ohlc'    : {'up':'r', 'down':'g'},'volume'  : {'up':'r', 'down':'g'}, #交易量颜色'vcdopcod': True, 'alpha'   : 1.0,},mavcolors     = ['#ef5714','#ef5714','#9f4878','#9f4878'], #均线颜色y_on_right    = False,gridcolor     = '#a0a0a0',gridstyle     = '--',facecolor     = 'w',rc            = [ ('axes.edgecolor'  , 'white'   ),('axes.linewidth'  ,  1.5      ),('axes.labelsize'  , 'large'   ),('axes.labelweight', 'semibold'),(&#id'       ,  True     ),(&#id.axis'  ,  'y'      ),('grid.linewidth'  ,  0.4      ),('lines.linewidth' ,  2.0      ),('font.weight'     , 'medium'  ),('font.size'       ,  10.0     ),('figure.titlesize', 'x-large' ),('figure.titleweight','semibold'),],base_mpf_style= 'charles')
#加上字体的设置,否则中文会乱码
normal_font = {'fontname':'STZhongsong','size':     '12','color':    'green','va':       'bottom','ha':       'left'}

获得K线数据

#获得均线
def MA(df,k):close = [float(x) for x in df['Close']]x=talib.MA(np.array(close), timeperiod=k)return x
df1['MA3']=MA(df,3)
df1['MA10']=MA(df,10)
df1['MA21']=MA(df,21)

画图

#选择自己的绘画风格
fig = mpf.figure(figsize=(10, 6),style=mystyle) 
ax1 = fig.add_subplot(2, 1, 1)
ax2 = fig.add_subplot(2, 1, 2, sharex=ax1)
fig.subplots_adjust(hspace=0)   #子图之间没有间隔
plt.xlabel('date',fontsize=10)  #指定X轴标签和大小
plt.tick_params(labelsize=6)#指定X轴刻度字体大小
#为子图1添加均线
ax1.plot(df1['Date'],df1['MA3'],label='MA3',color='slategray')
ax1.plot(df1['Date'],df1['MA10'],label='MA10',color='skyblue')
ax1.plot(df1['Date'],df1['MA21'],label='MA21',color='#ef5714')
ax1.legend(fontsize=7)
#用mplfinance画出蜡烛图
mpf.plot(df, type='candle',ylabel='Candle', axtitle='my style',ax=ax1,volume=ax2)

结果如图:

 

本文发布于:2024-02-04 10:58:43,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170705626854966.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:线图   tushare   mplfinance
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23