Matplotlib 简单绘图

1. 导入第三方包 numpy、matplotlib

# 导入numpy数组
import numpy as np

# 导入Matplotlib
import matplotlib.pyplot as plt

# 导入三维坐标轴图
from mpl_toolkits.mplot3d import Axes3D as plt_3d

 

2. 使用 plot() 绘图

# 等距离线性生成(0,50)的30个x数据
x = np.linspace(0, 50, 30)

# 生成y加上随机偏移量
y = 3 * x + np.random.randn(30)*5

# 生成连续图
plt.plot(x, y)

# 显示图形,在Jupyter中有没有这句都不影响
plt.show()

3. 初次使用figure框

# 等距离线性生成(0,50)的30个x数据
x = np.linspace(-5, 5, 30)

# 两种不同的关系式
y1 = 2*x + 8
y2 = x**2 - 3
# 使用一个图片框
plt.figure()
plt.plot(x, y1)
plt.show()

 

# 一个图片框也可以多个关系图
plt.figure()
plt.plot(x, y1)

# color=红色, linestyle=线条类型
plt.plot(x, y2, color='red', linestyle='--')
plt.show()

 

# 新生成一个图片框
plt.figure()

# 限制图片框的坐标限
plt.xlim((-3, 3))
plt.ylim((-5, 15))
plt.plot(x, y1)
plt.plot(x, y2, color='red', linestyle='--')
plt.show()

4. figure优化

# 等距离线性生成(0,50)的30个x数据
x = np.linspace(-5, 5, 30)

# 两种不同的关系式
y1 = 2*x + 8
y2 = x**2 - 3
# label=图标注解
plt.plot(x, y1, label='line', linestyle='--')
plt.plot(x, y2, label='cur', color='r')

# 显示图标
plt.legend()
plt.show()

5. 使用 scatter 绘制散点图

size = 128
# normal正态分布(均值,方差,数量)
x = np.random.normal(0, 1, size)
y = np.random.normal(0, 1, size)
color = np.arctan2(y, x)

# 设置两个坐标轴为空,即去除数字
plt.xticks(())
plt.yticks(())

# alpha: 透明度
plt.scatter(x, y, c=color, alpha=0.7)
plt.show()

6. 柱状图

size = 16
x = np.arange(size)

# 随便得出y值
y = x + np.random.randn(16)*(np.random.randint(16-x))

# 处理y为负值的情况
for i in range(16):
    if y[i]<0:
        y[i] = -y[i]

# 设置两个坐标轴为空,即去除数字
plt.xticks(())
plt.yticks(())

# 柱状图
plt.bar(x, y)
plt.show()

7. Image 图片

arr = np.random.randn(9).reshape(3, 3)

# Image图片
plt.imshow(arr, origin='upper', cmap='bone', interpolation='nearest')

# 颜色棒
plt.colorbar()

# 设置两个坐标轴为空,即去除数字
plt.xticks(())
plt.yticks(())
plt.show()

8. 3D 图像

fig = plt.figure()

# 生成3D视图对象
ax = plt_3d(fig)

# x、y、z 数值
x = np.arange(-4, 4, 0.25)
y = np.arange(-4, 4, 0.25)
x, y = np.meshgrid(x, y)
R = np.sqrt(x**2 + y**2)

z = np.sin(R)

ax.plot_surface(x, y, z, cmap=plt.get_cmap('rainbow'))

plt.show()

9. 使用 subplot 多合一显示

plt.figure()

# 整个figure分成 2*2 个,即两行两列,相当于讲一个figure中分割成四个小的figure,然后在里面绘图

# 第一张小图,占据两格
plt.subplot(2, 1, 1)
x = np.arange(16)
y = x + np.abs(np.random.randn(16)*(16-x))
# 绘图
plt.plot(x, y)

# 第二张小图
plt.subplot(2, 2, 3)
plt.scatter(x, y, color='r', alpha=0.7)

# 第三张小图
plt.subplot(2, 2, 4)
plt.bar(x, y, color='g')

plt.show()

 

posted @ 2021-04-18 18:24  a最简单  阅读(139)  评论(0编辑  收藏  举报