使用pcolor在matplotlib中创建热力图


首先,我们可以使用imshow方法创建一个图像,使用收获矩阵。之后,我们可以用一些值标记这些图像像素。

步骤

  • 创建一个科目列表。

  • 创建一个学生列表。

  • 创建一个收获矩阵。

  • 使用subplots方法创建fig和ax变量,其中默认的nrows和ncols为1。

  • 将数据显示为图像,即在二维规则光栅上,使用步骤1中的数据。

  • 获取或设置X轴的当前刻度位置和标签,长度为学生数量。

  • 获取或设置Y轴的当前刻度位置和标签,长度为科目数量。

  • 设置网格的X轴刻度标签,使用学生列表。

  • 设置网格的Y轴刻度标签,使用科目列表。

  • 设置艺术对象上的属性,包括旋转、水平对齐和rotation_mode="anchor"。

  • 使用text方法向绘图添加文本。

  • 使用set_title()方法为坐标轴设置标题。

  • 要显示图形,请使用plt.show()方法。

示例

import numpy as np
import matplotlib.pyplot as plt

subjects = ["math", "physics", "chemistry", "biology", "english"]
students = ["A", "B", "C", "D", "E"]

harvest = np.array([
   [1, 2, 3, 4, 5],
   [6, 7, 8, 9, 10],
   [11, 12, 13, 14, 15],
   [18, 19, 22, 14, 15],
   [5, 3, 2, 1, 6]
])
fig, ax = plt.subplots()
im = ax.imshow(harvest)

ax.set_xticks(np.arange(len(students)))
ax.set_yticks(np.arange(len(subjects)))

ax.set_xticklabels(students)
ax.set_yticklabels(subjects)

plt.setp(ax.get_xticklabels(), rotation=45, ha="right", rotation_mode="anchor")

for i in range(len(subjects)):
   for j in range(len(students)):
      text = ax.text(j, i, harvest[i, j], ha="center", va="center", color="w")

ax.set_title("Marks Distribution")

plt.show()

输出

更新于:2021年3月15日

410 次查看

开启你的职业生涯

完成课程后获得认证

开始学习
广告