数据可视化
Matplotlib入门
Matplotlib库的介绍
Matplotlib库的使用
Matplotlib库由各种可视化类构成,内部结构复杂,受Matlab启发
matplotlib.pyplot是绘制各类可视化图形的命令子库,相当于快捷方式
import matplotlib.pyplot as plt
plt.plot([3,1,4,5,2])
plt.ylabel("Grade")
plt.show()
- plt.plot()只有一个输入列表或数组时,参数被当作Y轴,X轴以索引自动生成
- plt.savefig()将输出图形存储为文件,默认PNG格式,可以通过dpi修改输出质量
- plt.plot(x,y)当有两个以上参数时,按照X轴和Y轴顺序绘制数据点
- plt,axis([x1,x2,y1,y2])表示x轴以x1起始,x2结束,y1,y2同理
pyplot的绘图区域
plt.subplot(nrows, ncols, plot_number)
import numpy as np
def f(t):
return np.exp(-t) * np.cos(2*np.pi*t)
a = np.arange(0.0,5.0,0.02)
plt.subplot(211)
plt.plot(a,f(a))
plt.subplot(2,1,2)
plt.plot(a,np.cos(2*np.pi*a),'r--')
plt.show()
pyplot的plot()函数
plt.plot(x, y, format_string, **kwargs)
- x : X轴数据,列表或数组,可选
- y : Y轴数据,列表或数组, 必须有
- format_string: 控制曲线的格式字符串,可选
- **kwargs : 第二组或更多(x,y,format_string)
- 当绘制多条曲线时,各条曲线的x不能省略
a = np.arange(10)
plt.plot(a,a*1.5 ,a,a*2.5, a,a*3.5, a,a*4.5)
plt.show()
format_string:
控制曲线的格式字符串,可选
由颜色字符、风格字符和标记字符组成
a = np.arange(10)
plt.plot(a, a*1.5, 'go-', a, a*2.5, 'rx', a, a*3.5, '*', a, a*4.5, 'b-.')
plt.show()
**kwargs
第二组或更多(x,y,format_string)
color : 控制颜色, color=‘green’
linestyle :线条风格, linestyle=‘dashed’
marker :标记风格, marker=‘o’
markerfacecolor : 标记颜色, markerfacecolor=‘blue’
markersize : 标记尺寸, markersize=20
pyplot的中文显示
pyplot并不默认支持中文显示,需要rcParams修改字体实现
matplotlib.rcParams['font.family'] = 'SimHei'
plt.plot([3,1,4,5,2])
plt.ylabel("纵轴(值)")
plt.savefig('test',dpi = 600)
plt.show()
rcParams的属性
中文字体的种类
matplotlib.rcParams['font.family'] = 'STSong'matplotlib.rcParams['font.size'] = 20a = np.arange(0.0,5.0,0.02)plt.xlabel("横轴:时间")plt.ylabel("纵轴:振幅")plt.plot(a,np.cos(2*np.pi*a),'r--')plt.show()
pyplot的中文显示:第二种方法
在有中文输出的地方,增加一个属性:fontproperties
a = np.arange(0.0,5.0,0.02)plt.xlabel("横轴:时间",fontproperties="SimHei",fontsize=20)plt.ylabel("纵轴:振幅",fontproperties="SimHei",fontsize=20)plt.plot(a,np.cos(2*np.pi*a),'r--')plt.show()
pyplot的文本显示
pyplot的文本显示函数
- plt.grid(True) # 显示网格线
a = np.arange(0.0,5.0,0.02)plt.xlabel("横轴:时间",fontproperties="SimHei",fontsize=15,color='green')plt.ylabel("纵轴:振幅",fontproperties="SimHei",fontsize=15)plt.title(r'正弦波实例$y=cos(2\pi x)$',fontproperties="SimHei",fontsize=25)plt.text(2,1,r'$\mu=100$',fontsize=15)plt.plot(a,np.cos(2*np.pi*a),'r--')plt.axis([-1,6,-2,2])plt.grid(True)plt.show()
plt.annotate(s, xy=arrow_crd, xytext=text_crd, arrowprops=dict)
a = np.arange(0.0,5.0,0.02)plt.plot(a,np.cos(2*np.pi*a),'r--')plt.xlabel("横轴:时间",fontproperties="SimHei",fontsize=25,color='green')plt.ylabel("纵轴:振幅",fontproperties="SimHei",fontsize=25)plt.title(r'正弦波实例$y=cos(2\pi x)$',fontproperties="SimHei",fontsize=25)plt.annotate(r'$\mu=100$',xy=(2,1),xytext=(3,1.5), arrowprops=dict(facecolor='black',shrink=0.1,width=2))plt.axis([-1,6,-2,2])plt.grid(True)plt.show()
pyplot的子绘图区域
plt.subplot2grid()
plt.subplot2grid(GridSpec, CurSpec, colspan=1, rowspan=1)
理念:设定网格,选中网格,确定选中行列区域数量,编号从0开始
plt.subplot2grid((3,3), (1,0), colspan=2)
def f(t): return np.exp(-t) * np.cos(2*np.pi*t)a = np.arange(0.0,5.0,0.02)plt.subplot2grid((3,3), (1,0), colspan=2)plt.plot(a,f(a))plt.subplot2grid((3,3), (2,0), colspan=2)plt.plot(a,f(a))plt.subplot2grid((3,3), (1,2))plt.plot([3,1,4,5,2])
GridSpec类
import matplotlib.gridspec as gridspecgs = gridspec.GridSpec(3,3)ax1 = plt.subplot(gs[0,:])ax2 = plt.subplot(gs[1,:-1])ax3 = plt.subplot(gs[1:,-1])ax4 = plt.subplot(gs[2,0])ax5 = plt.subplot(gs[2,1])