多子图
figure是绘制对象(可以理解为一个空白的画布),一个figure对象可以包含多个Axes子图,一个Axes是一个绘图区域,不加设置时,Axes为1,且每次绘图其实都是在figure上的Axes上绘图。
我们是在图形对象上面的Axes区域进行作画
1.add_axes():添加区域
2.Matplotlib定义一个axes类,该类的对象称为axes对象(即轴域对象),它指定一个有数值范围限制的绘图区域。再给定一个画布中,可以包含多个axes对象,但是同一个axes对象只能在一个画布中使用。
2D 绘制区域(axes)包含两个轴(axis)对象
语法:
add_axes(rect)
该方法用来生成一个axes轴域对象,对象的位置参数由参数rect决定。
rect是位置参数,接受一个由4个元素组成的浮点数列表,形如[left,bottom,width,height],它表示添加到画布中的矩形区域左下标(x,y),以及宽度和高度
1
2
3
4
5
6
7
8
9
|
fig=plt.figure(figsize=(4,2),facecolor='g')
#ax1从画布起始位置绘制,宽高和画布一致
ax1=fig.add_axes([0,0,1,1])
#ax2从画布20%的位置开始绘制,宽高是画布的50%
ax2=fig.add_axes([0.2,0.2,0.5,0.5])
ax3=fig.add_axes([0.0,0.5,0.5,0.5])
ax3.plot([1,2,3,4,6],[2,3,5,8,9])
ax1.plot([1,2,3,4,6],[2,3,5,8,9])
ax2.plot([1,2,3,4,6],[2,3,5,8,9])
|
注意:每个元素的值是画布宽度和高度的分数。即将画布的宽、高作为一个单位。比如,[0.2,0.2,0.5,0.5],它代表从画布20%的位置开始绘制,宽度是画布的50%
1
2
3
4
5
6
7
8
9
|
fig=plt.figure()
#创建区域1
ax1=fig.add_axes([0,0,1,1])
#区域1作画
plt.plot([1,2,3,4,6],[2,3,5,8,9])
#创建区域2
ax2=fig.add_axes([0.2,0.2,0.5,0.5])
#区域2作画
plt.plot([1,2,3,4,6],[2,3,5,8,9])
|
subplot():均等地划分画布,只是创建一个包含子图区域的画布(返回区域对象)
subplots():既创建一个包含子图区域的画布,又创建了一个figure的图形对象(返回图形对象和区域对象)
散点图
matplotlib.pyplot.scatter(s,y,s=None,marker=None,camp=None,norm=None,vmin=None,vmax=None,aipha=None,linewidths=None,edgecolors=None,plotnonfinite=False,data=None,*kwargs)
- x,y散点坐标
- s散点面积
- c散点颜色(默认为蓝色,‘b’,其余颜色同plt.plot())
- marker散点样式(默认为实心圆)
- alpha散点透明度([0,1]之间的数,0表示完全透明,1表示完全不透明)
- linewidths散点的边缘线宽
- edgecolors散点的边缘颜色
- camp(Colormap,默认None,标量是一个colormap的名字,只有c是一个浮点数组时才使用)
1
2
3
4
5
6
7
8
9
10
|
#x轴数据
x=np.array([1,2,3,4,5,6,7,8])
#y轴数据
y=np.array([]1,4,9,16,7,11,23,18)
#生成一个[0,1)之间的随机浮点数或N维浮点数组
print((20*np.random.rand(8)**2)
a=(20*np.random.rand(8))**2
plt.scatter(x,y,s)
plt.show()
|
自定义点的颜色和透明度
1
2
3
4
5
6
7
8
9
10
11
12
|
x=np.random.rand(50) #rand()生成一个[0,1)之间的随机浮点数或 N维浮点数组
#y轴数据
y=np.random.rand(50)
#生成一个浮点数组,取值范围,正态分布的随机样本数
s=(10*np.random.randn(50))**2
#颜色可以使用一组数字序列
#如只需要3中颜色
#color=np.resize(np.array([1,2,3]),100)
#颜色随机
color=np.random.rand(50)
plt.scatter(x,y,s,c=color.alpha=0.5![请添加图片描述](https://img-blog.csdnimg.cn/485575db5ab44419a8c885c2ed2fc7e6.jpeg)
)
|
水平柱状图
1
2
3
4
5
6
7
8
9
10
11
|
#引入Matplotlib
from matplotlib import pyplot as plt
import numpy as np
#设置中文字体
plt.rcParams['font.sans-serif']=['SimHei']
#中文负号
plt.rcParams['axes.unicode_minus']=False
#设置分辨率100
plt.rcParams['figure.dpi']=100
#设置大小
plt.rcParams['figure.figsize']=(5,3)
|
调用Matplptlib的barh()函数可以生成水平柱状图
barh()函数的用法与bar()函数的用法基本一样,只是在调用barh()函数使用y参数传入Y轴数据,使用width参数传入代表条柱 宽度的数据。
plt.barh(y,width,height=0.8,left=None,*,align=‘center’,**kwargs)
1
2
3
4
5
|
countries=['挪威','德国','中国','美国','瑞典']
#金牌个数
gold_medal=np.array([16,12,9,8,8])
#y轴为国家,宽度为奖牌个数
plt.barh(countries,width=gold_medal)
|
同位置柱状图
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
|
#国家
countries=['挪威','德国','中国','美国','瑞典']
#金牌个数
gold_metal=[16,12,9,8,8]
#银牌个数
silver_medal=[8,10,4,10,5]
#铜牌个数
bronze_metal=[13,5,2,7,5]
#1.将x轴转换为数值x=np.arange(len(countries))
print(x)
#2.设置图像宽度
width=0.2
#=======确定x起始位置=====
#金牌起始位置
gold_x=x
#银牌起始位置
sliver_x=x+width
#铜牌起始位置
bronze_x=x+2*width
#==============分别绘制图形
#金牌图形
plt.bar(gold_x,gold_medal,width=width,color='gold')
#银牌图形
plt.bar(silver_x,silver_medal,width=width,color='silver')
#铜牌图形
plt.bar(bronze_x,bronze_medal,width=width,color='saddlebrown')
#=====将x轴的坐标变回来
#注意x标签的位置居中
plt.xticks(x+width,labels=countries)
#------显示高度文本-------
for i in range(len(countries)):
#金牌文本设置
plt.text(gold_x[i],gold_medal[i],va="bottom",ha="center")
plt.text(silver_x[i],silver_medal[i],va="bottom",ha="center")
plt.text(bronze_x[i],bronze_medal[i],va="bottom",ha="center")
|
|