方法名 | 说明 |
---|---|
title() | 设置图表的名称 |
xlabel() | 设置 x 轴名称 |
ylabel() | 设置 y 轴名称 |
xticks(x, ticks, rotation) | 设置 x 轴的刻度,rotation 为刻度标签的旋转角度 |
yticks() | 设置 y 轴的刻度 |
plot() | 绘制线性图表 |
show() | 显示图表 |
legend() | 显示图例 |
text(x, y, text) | 显示每个数据点的值,x、y 为值的位置 |
figure(name, figsize=(w, h), dpi=n) | 设置图片的名称、大小和分辨率 |
import matplotlib.pyplot as plt
# 绘制折线图并设置样式
datas = [1, 2, 3, 4, 5]
squares = [1, 4, 9, 16, 25]
plt.plot(datas, squares, linewidth=5) # 设置线条宽度
# 设置图表标题, 并在坐标轴上添加标签
plt.title('', fontsize=24)
plt.xlabel('datas', fontsize=14)
plt.ylabel('squares', fontsize=14)
plt.rcParams['font.sans-serif'] = ['SimHei'] # matplotlib默认不支持中文标签,所以此行的目的是用来正常显示中文标签
plt.show()
Matplotlib 默认情况不支持中文(使用中文可能会出现乱码问题),可以使用以下简单的方法来解决:
plt.rcParams['font.sans-serif']=['SimHei'] #用来正常显示中文标签
# coding: utf-8
import matplotlib.pyplot as plt
import numpy as np
# 绘制sin和cos曲线
# 生成x的坐标(0-10的100个等差数列)
plt.figure('sin-cos', figsize=(10, 10))
x = np.linspace(0, 10, 200) # 生成将1-10(包含10)平均分为200份后的等差数列
print(len(x))
sin_y = np.sin(x)
# 绘制正弦曲线
plt.plot(x, sin_y)
# 绘制余弦曲线
cos_y = np.cos(x)
plt.plot(x, cos_y)
plt.show()
如果想绘制到两张画布中,可以调用 subplot()函数将画布分区。
# subplot()函数将画布分区的使用
# 将画布分为区域,将图画到画布的指定区域
x = np.linspace(1, 10, 100)
# 将画布分为2行2列, 将图画到画布的1区域
plt.subplot(2, 2, 1)
plt.plot(x, np.sin(x))
plt.subplot(2, 2, 3) # 将图画到画布的3区域
plt.plot(x, np.cos(x))
plt.show()
import matplotlib.pyplot as plt
import numpy as np
# 绘制散点图
x = np.linspace(0, 10, 100) # 生成0到10中100个数的等差数列
plt.scatter(x, np.sin(x))
plt.show()
# coding: utf-8
import matplotlib.pyplot as plt
import numpy as np
# 直线图
# # 将(0, 1)点和(2, 4)连起来
# # plot默认画直线
# plt.plot([0, 2], [1, 4])
# plt.show()
# # 折线图
# x = [1, 2, 3, 4, 5]
# squares = [1, 4, 9, 16, 25]
# plt.plot(x, squares)
# plt.show()
# # 绘制折线图并设置样式
# datas = [1, 2, 3, 4, 5]
# squares = [1, 4, 9, 16, 25]
# plt.plot(datas, squares, linewidth=5) # 设置线条宽度
# # 设置图表标题, 并在坐标轴上添加标签
# plt.title('', fontsize=24)
# plt.xlabel('datas', fontsize=14)
# plt.ylabel('squares', fontsize=14)
# plt.rcParams['font.sans-serif'] = ['SimHei'] # matplotlib默认不支持中文标签,所以此行用来正常显示中文标签
# plt.show()
#
# 绘制一元二次方程的曲线y=x^2
# 200个点的x坐标
x = range(200)
# 生成y点的坐标
y = [i**2 for i in x]
# 绘制一元二次曲线
plt.plot(x, y)
# 调用savefig将一元二次曲线保存为result.jpg
plt.savefig('result.jpg')
plt.show()
感兴趣的同志可以取消对应的注释, 去查看相应的图
result:
# coding: utf-8
import matplotlib.pyplot as plt
import numpy as np
# 绘制sin和cos曲线
# 生成x的坐标(0-10的100个等差数列)
plt.figure('sin-cos', figsize=(10, 10))
x = np.linspace(0, 10, 200) # 生成将1-10(包含10)平均分为200份后的等差数列
print(len(x))
sin_y = np.sin(x)
# 绘制正弦曲线
plt.plot(x, sin_y)
# 绘制余弦曲线
cos_y = np.cos(x)
plt.plot(x, cos_y)
plt.show()
# subplot()函数将画布分区的使用
# 将画布分为区域,将图画到画布的指定区域
x = np.linspace(1, 10, 100)
# 将画布分为2行2列, 将图画到画布的1区域
plt.subplot(2, 2, 1)
plt.plot(x, np.sin(x))
plt.subplot(2, 2, 3) # 将图画到画布的3区域
plt.plot(x, np.cos(x))
plt.show()
# 绘制散点图
x = np.linspace(0, 10, 100) # 生成0到10中100个数的等差数列
plt.scatter(x, np.sin(x))
plt.show()
# 画10种大小, 100中颜色的散点图
np.random.seed(0)
x = np.random.rand(100)
y = np.random.rand(100)
colors = np.random.rand(100)
size = np.random.rand(100)*1000 # size参数的长度要与x, y长度匹配
plt.scatter(x, y, c=colors, s=size, alpha=0.7)
plt.show()
# 绘制不同种类不同颜色的线
# 不同种类不同颜色的线并添加图例
x = np.linspace(0, 10, 100)
plt.plot(x, x + 0, '-g', label='-g') # 实线 绿色
plt.plot(x, x + 1, '--c', label='--c') # 虚线 浅蓝色
plt.plot(x, x + 2, '-.k', label='-.k') # 点划线 黑色
plt.plot(x, x + 3, '-r', label='-r') # 实线 红色
plt.plot(x, x + 4, 'o', label='o') # 点 默认是蓝色
plt.plot(x, x + 5, '-x', label='-x') # 叉叉 默认是蓝色
plt.plot(x, x + 6, 'dr', label='dr') # 砖石 红色
# 添加图例右下角lower right 左上角 upper left 边框 透明度 阴影 边框宽度
plt.legend(loc='lower right', fancybox=True, framealpha=1, shadow=True, borderpad=1)
plt.show()
因为我在绘制好一张图之后会注释掉, 然后在下面重新绘制新的图, 所以每次运行只会看到新的图, 但此处我把注释掉的代码给取消注释了, 感兴趣的同志可以复制下来去查看修改, 并且该程序是单线程的, 所以五张图不会同时弹出, 需要在关闭一张图之后才会弹出来另一张图表。为了能更直观的看到代码执行的结果, 我把每张图都给截图放到了下面。