Python - 将 NxN 矩阵绘制为渐变颜色网格

far*_*awa 0 python plot dataframe pandas

我想可视化我使用datafrome.corr()方法获得的列之间的相关性。

结果如下:

在此处输入图片说明

我在这里要做的是根据数据框的值用渐变颜色绘制该矩阵。

类似的东西(只是网络上的一个例子):

在此处输入图片说明

Dav*_*vid 5

如果您可以将数据导入 numpy,这里是一个使用 matplotlib 的简单解决方案,并且应该生成与您发布的内容类似的热图。您只需要用您的数据替换虚拟数据。

import numpy as np
import matplotlib.pyplot as plt

# Generate some test data
data = np.arange(100).reshape((10,10))

plt.title('Actual Function')
heatmap = plt.pcolor(data)
plt.show()
Run Code Online (Sandbox Code Playgroud)

编辑:这是一个带有 x 和 y 轴标签的更高级版本。我选择将它们分成两个列表,以便您可以单独更改每个列表。

import numpy as np
import matplotlib.pyplot as plt

# Generate some test data
data = np.arange(100).reshape((10,10))

xlabels = ['capacity', 'failure_rate', 'id', 'margin', 'price', 'prod_cost', 'product_type', 'quality', 'warranty', 'market_share', 'attractiveness']
ylabels = ['capacity', 'failure_rate', 'id', 'margin', 'price', 'prod_cost', 'product_type', 'quality', 'warranty', 'market_share', 'attractiveness']

fig, ax = plt.subplots()

ax.set_xticks(np.arange(data.shape[1]) + 0.5, minor=False)
ax.set_yticks(np.arange(data.shape[0]) + 0.5, minor=False)

ax.xaxis.tick_top()
plt.xticks(rotation=90)

ax.set_xticklabels(xlabels, minor=False)
ax.set_yticklabels(ylabels, minor=False)
heatmap = ax.pcolor(data)

ax = plt.gca()

for t in ax.xaxis.get_major_ticks():
    t.tick1On = False
    t.tick2On = False
for t in ax.yaxis.get_major_ticks():
    t.tick1On = False
    t.tick2On = False

plt.show()
Run Code Online (Sandbox Code Playgroud)