50题matplotlib从入门到精通
Matplotlib 是 Python 的绘图库。 它可与 NumPy 一起使用,提供了一种有效的 MatLab 开源替代方案,也可以和图形工具包一起使用。和Pandas、Numpy并成为数据科学三兄弟(我自己想的)。
点击此处,不用搭环境,直接在线运行👇
本教程部分参考:Matplotlib Tutorial for Beginners、宝可梦数据练手
文中提及数据集:宝可梦属性数据集
其他x题系列:
一、导入
1.导入matplotlib库简写为plt
import matplotlib.pyplot as plt
二、基本图表
2.用plot方法画出x=(0,10)间sin的图像
x = np.linspace(0, 10, 30)
plt.plot(x, np.sin(x));
data:image/s3,"s3://crabby-images/343cd/343cd0a8374f9b7b16954c7d31f763bce4470ca4" alt=""
3.用点加线的方式画出x=(0,10)间sin的图像
plt.plot(x, np.sin(x), '-o');
data:image/s3,"s3://crabby-images/7ea24/7ea24cad54b3d709a47b561aa1177d2850fba86b" alt=""
4.用scatter方法画出x=(0,10)间sin的点图像
plt.scatter(x, np.sin(x));
data:image/s3,"s3://crabby-images/37a3d/37a3d64bde635a543bb3e4b05ccde7aa527edf1d" alt=""
5.用饼图的面积及颜色展示一组4维数据
rng = np.random.RandomState(0)
x = rng.randn(100)
y = rng.randn(100)
colors = rng.rand(100)
sizes = 1000 * rng.rand(100)
plt.scatter(x, y, c=colors, s=sizes, alpha=0.3,
cmap='viridis')
plt.colorbar(); # 展示色阶
data:image/s3,"s3://crabby-images/34713/34713f4274392a165dcf436269cd2d125ac55813" alt=""
6.绘制一组误差为±0.8的数据的误差条图
x = np.linspace(0, 10, 50)
dy = 0.8
y = np.sin(x) + dy * np.random.randn(50)
plt.errorbar(x, y, yerr=dy, fmt='.k')
data:image/s3,"s3://crabby-images/08721/087213f6675d1ecb824d73220152595d9a2f4b80" alt=""
7.绘制一个柱状图
x = [1,2,3,4,5,6,7,8]
y = [3,1,4,5,8,9,7,2]
label=['A','B','C','D','E','F','G','H']
plt.bar(x,y,tick_label = label);
data:image/s3,"s3://crabby-images/6f214/6f214ee7995c880c1d473ee2ab55a22926d4e4e7" alt=""
8.绘制一个水平方向柱状图
plt.barh(x,y,tick_label = label);
data:image/s3,"s3://crabby-images/af3b7/af3b73242e11ef1ca7a02ff727af92205a5de090" alt=""
9.绘制1000个随机值的直方图
data = np.random.randn(1000)
plt.hist(data);
data:image/s3,"s3://crabby-images/24f3b/24f3be7489445e6c2410e99089b6e71a443767de" alt=""
10.设置直方图分30个bins,并设置为频率分布
plt.hist(data, bins=30,histtype='stepfilled', density=True)
plt.show();
data:image/s3,"s3://crabby-images/cd7c5/cd7c5f239f27a3751dfff5205c30e62ffde046b8" alt=""
11.在一张图中绘制3组不同的直方图,并设置透明度
x1 = np.random.normal(0, 0.8, 1000)
x2 = np.random.normal(-2, 1, 1000)
x3 = np.random.normal(3, 2, 1000)
kwargs = dict(alpha=0.3, bins=40, density = True)
plt.hist(x1, **kwargs);
plt.hist(x2, **kwargs);
plt.hist(x3, **kwargs);
data:image/s3,"s3://crabby-images/98880/9888076cc743ad848017a56d41aa7f7cd36c5883" alt=""
12.绘制一张二维直方图
mean = [0, 0]
cov = [[1, 1], [1, 2]]
x, y = np.random.multivariate_normal(mean, cov, 10000).T
plt.hist2d(x, y, bins=30);
data:image/s3,"s3://crabby-images/327b1/327b1e5e6bf8cfccf61d49205fb552e8d178cff6" alt=""
13.绘制一张设置网格大小为30的六角形直方图
plt.hexbin(x, y, gridsize=30);
data:image/s3,"s3://crabby-images/c8667/c86676e45212308c08d3a1f71b86a870b18a002c" alt=""
三、自定义图表元素
14.绘制x=(0,10)间sin的图像,设置线性为虚线
x = np.linspace(0,10,100)
plt.plot(x,np.sin(x),'--');
data:image/s3,"s3://crabby-images/b0c6b/b0c6ba6d8c083784b054c06bec5311bac8a2ff7c" alt=""
15设置y轴显示范围为(-1.5,1.5)
x = np.linspace(0,10,100)
plt.plot(x, np.sin(x))
plt.ylim(-1.5, 1.5);
data:image/s3,"s3://crabby-images/3fb2e/3fb2ef72b28cc428ee9aed0ac47776ebf46c3902" alt=""
16.设置x,y轴标签variable x,value y
x = np.linspace(0.05, 10, 100)
y = np.sin(x)
plt.plot(x, y, label='sin(x)')
plt.xlabel('variable x');
plt.ylabel('value y');
data:image/s3,"s3://crabby-images/f90eb/f90ebaafd624240f2422a0f2cdc8f7ff4b9f7613" alt=""
17.设置图表标题“三角函数”
x = np.linspace(0.05, 10, 100)
y = np.sin(x)
plt.plot(x, y, label='sin(x)')
plt.title('三角函数');
data:image/s3,"s3://crabby-images/a09ba/a09ba275a34dbe8d7abba3a369490aebe247f46e" alt=""
18.显示网格
x = np.linspace(0.05, 10, 100)
y = np.sin(x)
plt.plot(x, y)
plt.grid()
data:image/s3,"s3://crabby-images/f4be0/f4be04ef1aff3cd75db7d1dad1c13ae020d23b8a" alt=""
19.绘制平行于x轴y=0.8的水平参考线
x = np.linspace(0.05, 10, 100)
y = np.sin(x)
plt.plot(x, y)
plt.axhline(y=0.8, ls='--', c='r')
data:image/s3,"s3://crabby-images/58046/58046e4e57c68c38ec56cc38464acf7f09f9472e" alt=""
20.绘制垂直于x轴x<4 and x>6的参考区域,以及y轴y<0.2 and y>-0.2的参考区域
x = np.linspace(0.05, 10, 100)
y = np.sin(x)
plt.plot(x, y)
plt.axvspan(xmin=4, xmax=6, facecolor='r', alpha=0.3) # 垂直x轴
plt.axhspan(ymin=-0.2, ymax=0.2, facecolor='y', alpha=0.3); # 垂直y轴
data:image/s3,"s3://crabby-images/bb2f8/bb2f8fa11efdc6e7e9c1c8c9c0e254352af1d4b2" alt=""
21.添加注释文字sin(x)
x = np.linspace(0.05, 10, 100)
y = np.sin(x)
plt.plot(x, y)
plt.text(3.2, 0, 'sin(x)', weight='bold', color='r');
data:image/s3,"s3://crabby-images/7c1b2/7c1b2634d671d468fec9b016917761cde6f50e2a" alt=""
22.用箭头标出第一个峰值
x = np.linspace(0.05, 10, 100)
y = np.sin(x)
plt.plot(x, y)
plt.annotate('maximum',xy=(np.pi/2, 1),xytext=(np.pi/2+1, 1),
weight='bold',
color='r',
arrowprops=dict(arrowstyle='->', connectionstyle='arc3', color='r'));
data:image/s3,"s3://crabby-images/0da3f/0da3f546eb66bb88698713402189489d89bcc257" alt=""
四、自定义图例
23.在一张图里绘制sin,cos的图形,并展示图例
x = np.linspace(0, 10, 1000)
fig, ax = plt.subplots()
ax.plot(x, np.sin(x), label='sin')
ax.plot(x, np.cos(x), '--', label='cos')
ax.legend();
data:image/s3,"s3://crabby-images/a9c01/a9c013ecfe312d85dfb311f59d9dfb48c80c919f" alt=""
24.调整图例在左上角展示,且不显示边框
ax.legend(loc='upper left', frameon=False);
fig
data:image/s3,"s3://crabby-images/cfbae/cfbae6ec9f4866fd6abc5103e20a7415106ec588" alt=""
25.调整图例在画面下方居中展示,且分成2列
ax.legend(frameon=False, loc='lower center', ncol=2)
fig
data:image/s3,"s3://crabby-images/2132c/2132ce6823e6264569e5791e836a5c8d2920c1c1" alt=""
26.绘制的图像,并只显示前2者的图例
y = np.sin(x[:, np.newaxis] + np.pi * np.arange(0, 2, 0.5))
lines = plt.plot(x, y)
# lines 是 plt.Line2D 类型的实例的列表
plt.legend(lines[:2], ['first', 'second']);
# 第二个方法
#plt.plot(x, y[:, 0], label='first')
#plt.plot(x, y[:, 1], label='second')
#plt.plot(x, y[:, 2:])
#plt.legend(framealpha=1, frameon=True);
data:image/s3,"s3://crabby-images/da469/da469470a00214114130daba9185dcc0280baaae" alt=""
27.将图例分不同的区域展示
fig, ax = plt.subplots()
lines = []
styles = ['-', '--', '-.', ':']
x = np.linspace(0, 10, 1000)
for i in range(4):
lines += ax.plot(x, np.sin(x - i * np.pi / 2),styles[i], color='black')
ax.axis('equal')
# 设置第一组标签
ax.legend(lines[:2], ['line A', 'line B'],
loc='upper right', frameon=False)
# 创建第二组标签
from matplotlib.legend import Legend
leg = Legend(ax, lines[2:], ['line C', 'line D'],
loc='lower right', frameon=False)
ax.add_artist(leg);
data:image/s3,"s3://crabby-images/6514e/6514ecb98cb7497958d1db7e98b561c642446352" alt=""
五、自定义色阶
28.展示色阶
x = np.linspace(0, 10, 1000)
I = np.sin(x) * np.cos(x[:, np.newaxis])
plt.imshow(I)
plt.colorbar();
data:image/s3,"s3://crabby-images/85079/85079e121c7947a8dcffe5109936b63073f2b606" alt=""
29.改变配色为'gray'
plt.imshow(I, cmap='gray');
data:image/s3,"s3://crabby-images/00194/00194f414dd602de3ecbbc02de530151bc8d6033" alt=""
30.将色阶分成6个离散值显示
plt.imshow(I, cmap=plt.cm.get_cmap('Blues', 6))
plt.colorbar()
plt.clim(-1, 1);
data:image/s3,"s3://crabby-images/0fc12/0fc12b0c88e1fbd00a1f7535a41c29919624a0ce" alt=""
六、多子图
31.在一个1010的画布中,(0.65,0.65)的位置创建一个0.20.2的子图
ax1 = plt.axes()
ax2 = plt.axes([0.65, 0.65, 0.2, 0.2])
data:image/s3,"s3://crabby-images/9be88/9be88fc0ae19bf5df3194cc64a82aeece58b8c2a" alt=""
32.在2个子图中,显示sin(x)和cos(x)的图像
fig = plt.figure()
ax1 = fig.add_axes([0.1, 0.5, 0.8, 0.4], ylim=(-1.2, 1.2))
ax2 = fig.add_axes([0.1, 0.1, 0.8, 0.4], ylim=(-1.2, 1.2))
x = np.linspace(0, 10)
ax1.plot(np.sin(x));
ax2.plot(np.cos(x));
data:image/s3,"s3://crabby-images/7d52d/7d52d659e909407538d2b51f9c889d71ec2c79e5" alt=""
33.用for创建6个子图,并且在图中标识出对应的子图坐标
for i in range(1, 7):
plt.subplot(2, 3, i)
plt.text(0.5, 0.5, str((2, 3, i)),fontsize=18, ha='center')
# 方法二
# fig = plt.figure()
# fig.subplots_adjust(hspace=0.4, wspace=0.4)
# for i in range(1, 7):
# ax = fig.add_subplot(2, 3, i)
# ax.text(0.5, 0.5, str((2, 3, i)),fontsize=18, ha='center')
data:image/s3,"s3://crabby-images/9e10c/9e10ce7975adacbedd9ec4680cc26af5726fdd1d" alt=""
34.设置相同行和列共享x,y轴
fig, ax = plt.subplots(2, 3, sharex='col', sharey='row')
data:image/s3,"s3://crabby-images/5fe1a/5fe1a75aa5c6bc41b7b12db16e531b44cf557267" alt=""
35.用[]的方式取出每个子图,并添加子图座标文字
for i in range(2):
for j in range(3):
ax[i, j].text(0.5, 0.5, str((i, j)),fontsize=18, ha='center')
fig
data:image/s3,"s3://crabby-images/98df2/98df28fdd68fac5c121f31a94d89703f4d87f6eb" alt=""
36.组合绘制大小不同的子图,样式如下
data:image/s3,"s3://crabby-images/04520/04520a33aaf44cfaccba4f708c51bb45b64de036" alt=""
grid = plt.GridSpec(2, 3, wspace=0.4, hspace=0.3)
plt.subplot(grid[0, 0])
plt.subplot(grid[0, 1:])
plt.subplot(grid[1, :2])
plt.subplot(grid[1, 2]);
37.显示一组二维数据的频度分布,并分别在x,y轴上,显示该维度的数据的频度分布
mean = [0, 0]
cov = [[1, 1], [1, 2]]
x, y = np.random.multivariate_normal(mean, cov, 3000).T
# Set up the axes with gridspec
fig = plt.figure(figsize=(6, 6))
grid = plt.GridSpec(4, 4, hspace=0.2, wspace=0.2)
main_ax = fig.add_subplot(grid[:-1, 1:])
y_hist = fig.add_subplot(grid[:-1, 0], xticklabels=[], sharey=main_ax)
x_hist = fig.add_subplot(grid[-1, 1:], yticklabels=[], sharex=main_ax)
# scatter points on the main axes
main_ax.scatter(x, y,s=3,alpha=0.2)
# histogram on the attached axes
x_hist.hist(x, 40, histtype='stepfilled',
orientation='vertical')
x_hist.invert_yaxis()
y_hist.hist(y, 40, histtype='stepfilled',
orientation='horizontal')
y_hist.invert_xaxis()
data:image/s3,"s3://crabby-images/dcdc6/dcdc6b41d8a75b44eaf5abf4f36b9cb8a247e7bb" alt=""
七、三维图像
38.创建一个三维画布
from mpl_toolkits import mplot3d
fig = plt.figure()
ax = plt.axes(projection='3d')
data:image/s3,"s3://crabby-images/dd767/dd7678e0877fe8bab26d0c3a8a1c33201e3340b9" alt=""
39.绘制一个三维螺旋线
ax = plt.axes(projection='3d')
# Data for a three-dimensional line
zline = np.linspace(0, 15, 1000)
xline = np.sin(zline)
yline = np.cos(zline)
ax.plot3D(xline, yline, zline);
data:image/s3,"s3://crabby-images/f2e4a/f2e4a7229f166464bf5aa4fc239ee6acbfeb7e1c" alt=""
40.绘制一组三维点
ax = plt.axes(projection='3d')
zdata = 15 * np.random.random(100)
xdata = np.sin(zdata) + 0.1 * np.random.randn(100)
ydata = np.cos(zdata) + 0.1 * np.random.randn(100)
ax.scatter3D(xdata, ydata, zdata, c=zdata, cmap='Greens');
data:image/s3,"s3://crabby-images/88368/88368a3cb7cba3c65e749a8ea079fbd759747a0a" alt=""
八、宝可梦数据集可视化
41.展示前5个宝可梦的Defense,Attack,HP的堆积条形图
pokemon = df['Name'][:5]
hp = df['HP'][:5]
attack = df['Attack'][:5]
defense = df['Defense'][:5]
ind = [x for x, _ in enumerate(pokemon)]
plt.figure(figsize=(10,10))
plt.bar(ind, defense, width=0.8, label='Defense', color='blue', bottom=attack+hp)
plt.bar(ind, attack, width=0.8, label='Attack', color='gold', bottom=hp)
plt.bar(ind, hp, width=0.8, label='Hp', color='red')
plt.xticks(ind, pokemon)
plt.ylabel("Value")
plt.xlabel("Pokemon")
plt.legend(loc="upper right")
plt.title("5 Pokemon Defense & Attack & Hp")
plt.show()
data:image/s3,"s3://crabby-images/dc029/dc029d4f62a1828dcd5f52d3d01f31cf469c82ab" alt=""
42.展示前5个宝可梦的Attack,HP的簇状条形图
N = 5
pokemon_hp = df['HP'][:5]
pokemon_attack = df['Attack'][:5]
ind = np.arange(N)
width = 0.35
plt.bar(ind, pokemon_hp, width, label='HP')
plt.bar(ind + width, pokemon_attack, width,label='Attack')
plt.ylabel('Values')
plt.title('Pokemon Hp & Attack')
plt.xticks(ind + width / 2, (df['Name'][:5]),rotation=45)
plt.legend(loc='best')
plt.show()
data:image/s3,"s3://crabby-images/210b6/210b689f98b7663cf287f0032262faf54886040a" alt=""
43.展示前5个宝可梦的Defense,Attack,HP的堆积图
x = df['Name'][:4]
y1 = df['HP'][:4]
y2 = df['Attack'][:4]
y3 = df['Defense'][:4]
labels = ["HP ", "Attack", "Defense"]
fig, ax = plt.subplots()
ax.stackplot(x, y1, y2, y3)
ax.legend(loc='upper left', labels=labels)
plt.xticks(rotation=90)
plt.show()
data:image/s3,"s3://crabby-images/05b45/05b45486167c794b8c1736bdab1c700fede8e602" alt=""
44.公用x轴,展示前5个宝可梦的Defense,Attack,HP的折线图
x = df['Name'][:5]
y1 = df['HP'][:5]
y2 = df['Attack'][:5]
y3 = df['Defense'][:5]
# Create two subplots sharing y axis
fig, (ax1, ax2,ax3) = plt.subplots(3, sharey=True)
ax1.plot(x, y1, 'ko-')
ax1.set(title='3 subplots', ylabel='HP')
ax2.plot(x, y2, 'r.-')
ax2.set(xlabel='Pokemon', ylabel='Attack')
ax3.plot(x, y3, ':')
ax3.set(xlabel='Pokemon', ylabel='Defense')
plt.show()
data:image/s3,"s3://crabby-images/0c565/0c5654376633f0bc6f421183c1c90577b4073f0a" alt=""
45.展示前15个宝可梦的Attack,HP的折线图
plt.plot(df['HP'][:15], '-r',label='HP')
plt.plot(df['Attack'][:15], ':g',label='Attack')
plt.legend();
data:image/s3,"s3://crabby-images/ee0cf/ee0cfcf472868d1f53148518fb9de57931181774" alt=""
46.用scatter的x,y,c属性,展示所有宝可梦的Defense,Attack,HP数据
x = df['Attack']
y = df['Defense']
colors = df['HP']
plt.scatter(x, y, c=colors, alpha=0.5)
plt.title('Scatter plot')
plt.xlabel('HP')
plt.ylabel('Attack')
plt.colorbar();
data:image/s3,"s3://crabby-images/14c46/14c46b00c1c1e7714d1dcc466e485ad9e080b84a" alt=""
47.展示所有宝可梦的攻击力的分布直方图,bins=10
x = df['Attack']
num_bins = 10
n, bins, patches = plt.hist(x, num_bins, facecolor='blue', alpha=0.5)
plt.title('Histogram')
plt.xlabel('Attack')
plt.ylabel('Value')
plt.show()
data:image/s3,"s3://crabby-images/8903f/8903f12d718a99cd74bc1f8bd09abe412e175d39" alt=""
48.展示所有宝可梦Type 1的饼图
plt.figure(1, figsize=(8,8))
df['Type 1'].value_counts().plot.pie(autopct="%1.1f%%")
plt.legend()
data:image/s3,"s3://crabby-images/e128e/e128ed080ef4929e166a9068ca40418cf4c577e7" alt=""
49.展示所有宝可梦Type 1的柱状图
ax = df['Type 1'].value_counts().plot.bar(figsize = (12,6),fontsize = 14)
ax.set_title("Pokemon Type 1 Count", fontsize = 20)
ax.set_xlabel("Pokemon Type 1", fontsize = 20)
ax.set_ylabel("Value", fontsize = 20)
plt.show()
data:image/s3,"s3://crabby-images/5fcf8/5fcf8abeb430e88cb870ee876dee4affce2d072e" alt=""
50.展示综合评分最高的10只宝可梦的系数间的相关系数矩阵
import seaborn as sns
top_10_pokemon=df.sort_values(by='Total',ascending=False).head(10)
corr=top_10_pokemon.corr()
fig, ax=plt.subplots(figsize=(10, 6))
sns.heatmap(corr,annot=True)
ax.set_ylim(9, 0)
plt.show()
data:image/s3,"s3://crabby-images/900d2/900d2ef382630bbdcd151a5da2d69cc0d4e11e9a" alt=""
点击此处,不用搭环境,直接在线运行👇