Matplotlib库入门

基本使用

关键是如何根据数据特点找到合适的图形来呈现(图形的绘制以及具体参数设计需要经验

Matplotlib库的效果

数据可视化第三方库,由各种可视化类构成,内部结构复杂,受Matlab启发

mtaplotlib.pyplot是绘制各类可视化图形的命令子库,相当于快捷方式

简单使用

1
2
3
4
5
import matplotlib.pyplot as plt
plt.plot([3,1,4,5,2]) #对于只有一个参数,则横坐标默认为其数组下标
plt.ylabel("Grade")
plt.savefig('test',dpi=600) #PNG文件
plt.show()

plt.savefig()将输出图形存储为文件,默认PNG格式,可以通过dpi修改输出质量(每一英寸中包含点的数量)

1
2
3
4
5
import matplotlib.pyplot as plt
plt.plot([0,2,4,6,8],[3,1,4,5,2]) #两个以上参数时,按照x轴和y轴顺序绘制数据点
plt.ylabel("Grade")
plt.axis([-1,10,0,6]) #设置横纵坐标尺度的函数,参数为有四个变量的列表,如-1,10,表明x轴起始于-1,终止于10
plt.show()

绘图区域

1
2
3
4
plt.subplot(nrows,ncols,plot_number)	#横轴数量,纵轴数量,当前在绘图区的哪个区域
plt.subplot(3,2,4)
plt.subplot(324)
###在全局绘图区域中创建一个分区体系,并定位到一个子绘图区域

image-20240515120854321

1
2
3
4
5
6
7
8
9
10
11
12
13
14
import numpy as np
import matplotlib.pyplot as plt

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)
    • color:控制颜色,color=’green’
    • linestyle:线条风格,linestyle=’dashed’
    • marker:标记风格,marker=’o’
    • markerfacecolor:标记颜色,markerfacecolor=’blue’
    • markersize:标记尺寸,markersize=20

format_string

1
2
3
#尝试绘制四条曲线
a = np.arange(10)
plt.plot(a,a*1.5,'go-',a*2.5,'rx',a,a*3.5,'*',a,a*4.5,'b-.')

image-20240515222115859

控制曲线的格式字符串,可选由颜色字符、风格字符和标记字符组成

颜色字符

颜色字符 说明 颜色字符 说明
‘b’ 蓝色 ‘m’ 洋红色 magenta
‘g’ 绿色 ‘y’ 黄色
‘r’ 红色 ‘k’ 黑色
‘c’ 青绿色 ‘w’ 白色
‘#008000’ RGB某颜色 ‘0.8’ 灰度值字符串

风格字符

风格字符 说明
‘-‘ 实线
‘—‘ 破折线
‘-.’ 点划线
‘:’ 虚线
‘ ‘ ‘ ‘ 无线条

标记字符

标记字符 说明 标记字符 说明 标记字符 说明
‘.’ 点标记 ‘1’ 下花三角标记 ‘h’ 竖六边形标记
‘,’ 像素标记(极小点) ‘2’ 上花三角标记 ‘H’ 横六边形标记
‘o’ 实心圈标记 ‘3’ 左花三角标记 ‘+’ 十字标记
‘v’ 倒三角标记 ‘4’ 右花三角标记 ‘x’ x标记
‘^’ 上三角标记 ‘s’ 实心方形标记 ‘D’ 菱形标记
‘>’ 右三角标记 ‘p’ 实心五角标记 ‘d’ 瘦菱形标记
‘<’ 左三角标记 ‘*’ 星形标记 ‘\ 垂直线标记

Pyplot的中文显示

pyplot并不默认支持中文显示

rcParams

rcParams修改字体实现

属性 说明
‘font.family’ 用于显示字体的名字
‘font.style’ 字体风格,正常’normal’或斜体’italic’
‘font.size’ 字体大小,整数字号或者’large’、’x-small’
1
2
3
4
5
6
7
8
9
10
import matplotlib.pyplot as plt
import matplotlib

matplotlib.rcParams['font.family']='SimHei'
# 'SimHei' 中文黑体 'Kaiti' 中文楷体 'Lisu' 中文隶书
# 'FangSong' 中文仿宋 'YouYuan' 中文幼圆 'STSong' 华文宋体
plt.plot([3,1,4,5,2])
plt.ylabel("纵轴(值)")
plt.savefig('test',dpi=600)
plt.show()

image-20240515223858518

1
2
3
4
5
6
7
8
9
10
11
12
13
import numpy as np
import matplotlib.pyplot as plt
import matplotlib

matplotlib.rcParams['font.family']='STSong'
matplotlib.rcParams['font,.size']=20

a = np.arange(0.0,5.0,0.02)

plt.xlabel('横轴:时间')
plt.ylabel('纵轴:振幅')
plt.plot(a,np.cos(2*np.pi*a),'r--')
plt.show()

image-20240515225245367

fontproperties

在有中文输出的地方,增加一个属性:fontproperties

1
2
3
4
5
6
7
8
9
import numpy as np
import matplotlib.pyplot as plt

a = np.arange(0.0,5.0,0.02)

plt.xlabel('横轴:时间',fontproperties='SimHei',fontsize=20)
plt.xlabel('纵轴:振幅',fontproperties='SimHei',fontsize=20)
plt.plot(a,np.cos(2*np.pi*a),'r--')
plt.show()

Pyplot的文本显示

函数 说明
plt.xlabel() 对x轴增加文本标签
plt.ylabel() 对y轴增加文本标签
plt.title() 对图形整体增加文本标签
plt.text() 在任意位置增加文本
plt.annotate() 在图形中增加带箭头的注解
1
2
3
4
5
6
7
8
9
10
11
12
13
14
import numpy as np
import matplotlib.pyplot as plt

a = np.arange(0.0,5.0,0.02)
plt.plot(a,np.cos(2*np.pi*a),'r--')

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.axis([-1,6,-2,2])
plt.grid(True) #网格
plt.show()

image-20240515231710356

plt.annotate()

1
plt.annotate(s,xy=arrow_crd,xytext=text_crd,arrowprops=dict)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
import numpy as np
import matplotlib.pyplot as plt

a = np.arange(0.0,5.0,0.02)
plt.plot(a,np.cos(2*np.pi*a),'r--')

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.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()

image-20240515232559993

PyPlot子绘图区域

subplot2grid

1
2
plt.subplot2grid(GridSpec,CurSPec,colspan=1,rowspan=1)
#理念:设定网格,选中网格,确定选中行列区域数量,编号从0开始
1
2
3
4
5
6
7
8
9
10
plt.subplot2grid((3,3),(0,0),colspan=3)
...
plt.subplot2grid((3,3),(1,0),colspan=2) #(3,3)三行三列九块 (1,0)表示第一行第零列 colspan表示列的延申
...
plt.subplot2grid((3,3),(1,2),rowspan=2)
...
plt.subplot2grid((3,3),(2,0))
...
plt.subplot2grid((3,3),(2,1))
...

image-20240515235038838

GridSpec类

1
2
3
4
5
6
7
8
9
import matplotlib.gridspec as gridspec

gs = 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])

Pyplot基础图标函数

函数 说明 函数 说明
plt.plot(x,y,fmt,…) 绘制一个坐标图 plt.psd(x,NFFT=256,pad_to,Fs) 绘制功率密度图
plt.boxplot(data,notch,position) 绘制一个箱型图 plt.specgram(x,NFFT=256,pad_to,F) 绘制谱图
plt.bar(left,height,width,bottom) 绘制一个条形图 pltcohere(x,y,NFFT=256,Fs) 绘制X-Y的相关性函数
plt.barh(width,bottom,left,height) 绘制一个横向条形图 plt.scatter(x,y) 绘制散点图,其中,x和y长度相同
plt.polar(theta,r) 绘制极坐标图 plt.step(x,y,where) 绘制步阶图
plt.pie(data,explode) 绘制饼图 plt.hist(x,bins,normed) 绘制直方图
plt.contour(X,Y,Z,N) 绘制等值图 plt.stem(x,y,linefmt,markerfmt) 绘制柴火图
plt.vlines() 绘制垂直图 plt.plot_date() 绘制数据日期

Pyplot的饼图绘制

1
2
3
4
5
6
7
8
9
10
11
12
13
import matplotlib.pyplot as plt

labels = 'Forgs','Hogs','Dogs','Logs'
sizes = [15,30,45,10]
explode = (0,0.1,0,0)

plt.pie(sizes,explode=explode,labels=labels,autopct='%1.1f%%',
shadow=False,startangle=90)
#explode:哪一块应该突出出来 label:标签 autoopct:中间显示百分号的方式
#shadow:饼图是否带有阴影效果 startangle:饼图起始角度
plt.axis('equal')
#饼图变成标准圆饼图
plt.show()

image-20240516121839567

Pyplot的直方图绘制

直方图,看数据分布

1
2
3
4
5
6
7
8
9
10
11
12
13
import numpy as np
import matplotlib.pyplot as plt

np.random.seed(0)
mu,sigma = 100,20
a = np.random.normal(mu,sigma,size=100)

plt.hist(a,20,normed=1,histtype='stepfilled',facecolor='b',alpha=0.75)
#bin:最小值和最大值之间均分,分割的直方图的个数
#normed=1时,将每一个区间数出现的个数归一化为出现的概率
plt.title('Histogram')

plt.show()

image-20240516122227339

Pyplot极坐标绘制

面向对象绘制极坐标(体会即可)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
import numpy as np
import matplotlib.pyplot as plt

N = 20
theta = np.linspace(0.0,2*np.pi,N,edpoint=False)
#从0到2pi等分出N个不同角度
radii = 10*np.random.rand(N)
#生成每个角度对应的值
width = np.pi / 4 * np.random.rand(N)

ax = plt.subplot(111,projection='ploar')
#子绘图区域形成的对象,projection作出绘制极坐标指示
bars = ax.bar(theta,radii,wiidth=width,bottom=0.0)
#theta:left radii:height
for r,bar in zip(radii,bars):
bar.set_facecolor(plt.cm.viridis(r/10.))
bar.set_alpha(0.5)

plt.show()

image-20240516165312870

Pyplot散点图绘制

1
2
3
4
5
6
7
8
9
10
import numpy as np
import matplotlib.pyplot as plt

fig,ax = plt.subplots()
#ax为绘图区域对象,这里没参数则默认为111
ax.plot(10*np.random.randn(100),10*np.random.randn(100),'o')
#正态产生的点搞分散些
ax.set_title('Simple Scatter')

plt.show()

image-20240516210019547

引力波的绘制示例

物理学中,引力波是因为时空弯曲对外以辐射形式传播的能量

爱因斯坦基于广义相对论预言了引力波的存在

绘制最原始的引力波和理想引力波

下载三个文件](https://python123.io/dv/grawave.html))

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
import numpy as np
import matplotlib.pyplot as plt
from scipy.io import wavfile

rate_h,hstrain = wavfile.read(r"H1_Strain.wav","rb")
rate_l,lstrain = wavfile.read(r"L1_Strain.wav","rb")
reftime,ref_H1 = np.genfromtxt('wf_template.txt').transpose()
#np.genfromtxt中有两个循环,第一个循环将文件每一行都转化为字符串序列,第二个循环将每一个字符串序列转化成相应数据类型
#这样生成一个两行的矩阵,不便于拆分,因此用transpose进行转置
htime_interval = 1/rate_h
ltime_interval = 1/rate_l
#速率求导数获得波形的时间间隔
htime_len = hstrain.shape[0]/rate_h
#strain是一个数据矩阵,shape[0]指的是获取第一维度的长度,即数据点的个数,数据个数乘上时间间隔得坐标轴总长度
htime = np.arange(-htime_len/2,htime_len/2,htime_interval)
ltime_len = lstrain.shape[0]/rate_l
ltime = np.arange(-ltime_len/2,ltime_len/2,ltime_interval)

###绘制H1 Strain###
fig = plt.figure(figsize=(12,6)) #创建一个大小为12*6的绘图空间

plth = fig.add_subplot(221)
plth.plot(htime,hstrain,'y')
plth.set_xlabel('Time(seconds)')
plth.set_ylabel('H1 Strain')
plth.set_title('H1 Strain')

pltl = fig.add_subplot(222)
pltl.plot(ltime,lstrain,'g')
pltl.set_xlabel('Time(seconds)')
pltl.set_ylabel('L1 Strain')
pltl.set_title('L1 Strain')

pltref = fig.add_subplot(212)
pltref.plot(reftime,ref_H1)
pltref.set_xlabel('Time(seconds)')
pltref.set_ylabel('Template Strain')
pltref.set_title('Template')
fig.tight_layout()#自动调整图像外围间距

plt.savefig("Gravitational_waves_Original.png")
plt.show()
plt.close(fig)

Matplotlib库入门
http://example.com/2024/05/14/20240514_Matplotlib/
作者
XuanYa
发布于
2024年5月14日
许可协议