python 画k线_使用matplotlib绘制k线图

利用matplotlib.finance绘制K线图时使用关键要点

绘制k线图的核心语句是:

import matplotlib.finance as mpf

mpf.candlestick_ochl( ax, matrix_data, colorup=***, colordown=***)

这其中 ax 是 matploblib 的 axis,matrix_data 是股价数据。

matrix_data 是 np.matrix 对象,对于 candlestick_ochl 方法来讲,它需要按照约定的顺序来排列数据,即 matrix_data 每一行中前五个数据必须是:时间、开盘价、收盘价、最高价、最低价。

在这里,“时间”不是 datetime 对象,也不是 string,它必须使用 matplotlib.pylab 中的 date2num(datetime) 方法来将datetime对象转换一个特定的时间戳数字。

通常我们会用 pandas.DataFrame 来储存股价数据——比如,利用 pd.read_csv() 读取 csv 文件后,得到就是一个 DataFrame 对象。假定 DataFrame 中包含有 date, open, close, high, low, volume 六列数据,在将其转化为 candlestick_ochl() 中所需的 matrix_data,要做如下几步工作:

删除空行

按时间升序排列数据

将date转化为特定的时间戳数据

按照 date,open,close,high,low,volume 的顺序重新排列 DataFrame

将 DataFrame 转为 matrix

删除空行

假定 pd.read_csv() 读入的数据为 data

data[data['volume']==0]=np.nan

data=data.dropna()

按时间升序排列数据

data.sort_values(by='date',ascending=True,inplace=True)

将date转化为特定的时间戳数据

from matplotlib.pylab import date2num

data.date=data.date.apply(lambda x:date2num(x))

按照 date,open,close,high,low,volume 的顺序重新排列 DataFrame

data=data[['date','open','close','high','low','volume']]

将 DataFrame 转为 matrix

data_mat=data.as_matrix()

合成代码案例

绘制k线

import matplotlib.pyplot as plt

import matplotlib.finance as mpf

import numpy as np

import pandas as pd

from matplotlib.pylab import date2num

data=pd.read_csv(u'兴业银行.csv',usecols=['date','open','close','high','low','volume'])

data[data['volume']==0]=np.nan

data=data.dropna()

data.sort_values(by='date',ascending=True,inplace=True)

data=data[['date','open','close','high','low','volume']]

# data=data.head(60)

data.date=pd.to_datetime(data.date)

data.date=data.date.apply(lambda x:date2num(x))

data_mat=data.as_matrix()

fig,ax=plt.subplots(figsize=(1200/72,480/72))

fig.subplots_adjust(bottom=0.1)

mpf.candlestick_ochl(ax,data_mat,colordown='#53c156', colorup='#ff1717',width=0.3,alpha=1)

ax.grid(True)

ax.xaxis_date()

plt.show()

a4b6e1d7ce94

candle.png

并置成交量图

fig,(ax1,ax2)=plt.subplots(2,sharex=True,figsize=(1200/72,480/72))

mpf.candlestick_ochl(ax1,data_mat,colordown='#53c156', colorup='#ff1717',width=0.3,alpha=1)

ax1.grid(True)

ax1.xaxis_date()

plt.bar(data_mat[:,0],data_mat[:,5],width=0.5)

ax2.set_ylabel('Volume')

ax2.grid(True)

plt.show()

a4b6e1d7ce94

k.png

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用matplotlib绘制k线图,需要以下步骤: 1. 导入matplotlib库以及其他需要的库: ```python import matplotlib.pyplot as plt import mpl_finance as mpf import pandas as pd ``` 2. 准备数据。k线图通常使用开盘价、最高价、最低价和收盘价来绘制。这些数据可以从一个pandas数据框中提取: ```python data = pd.read_csv('data.csv') open_price = data['open'] high_price = data['high'] low_price = data['low'] close_price = data['close'] ``` 3. 创建一个子图并绘制k线图。可以使用mpl_finance库中的candlestick_ochl函数来绘制k线图: ```python fig, ax = plt.subplots(figsize=(10,5)) mpf.candlestick_ochl(ax, zip(range(len(data)), open_price, close_price, high_price, low_price), width=0.4, colorup='r', colordown='g') ``` 这里创建了一个10x5的子图,然后使用zip函数将开盘价、收盘价、最高价和最低价打包在一起,然后将它们传递给candlestick_ochl函数来绘制k线图。width参数控制k线的宽度,colorup和colordown参数控制上涨和下跌的颜色。 4. 添加x轴和y轴标签以及其他的样式和标记: ```python ax.set_xticks(range(0, len(data), 30)) ax.set_xticklabels(data['date'][::30]) ax.set_xlabel('Date') ax.set_ylabel('Price') ax.xaxis_date() ax.grid(True) plt.title('Stock Price') plt.show() ``` 这些代码将x轴标记设置为每30个交易日一个标记,并将标记的标签设置为日期。然后设置x轴和y轴的标签,并将x轴的刻度设置为日期格式。最后添加网格和标题,并显示图形。 完整的代码如下: ```python import matplotlib.pyplot as plt import mpl_finance as mpf import pandas as pd data = pd.read_csv('data.csv') open_price = data['open'] high_price = data['high'] low_price = data['low'] close_price = data['close'] fig, ax = plt.subplots(figsize=(10,5)) mpf.candlestick_ochl(ax, zip(range(len(data)), open_price, close_price, high_price, low_price), width=0.4, colorup='r', colordown='g') ax.set_xticks(range(0, len(data), 30)) ax.set_xticklabels(data['date'][::30]) ax.set_xlabel('Date') ax.set_ylabel('Price') ax.xaxis_date() ax.grid(True) plt.title('Stock Price') plt.show() ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值