可视化 -- 绘制热图

  • 如果要表示一个 x , y x,y x,y坐标处的一些特征,直观会想到用灰度图以及由灰度转换出来的彩图。但是这样实际操作起来是不太方便的,明明有专门的绘图工具,何必做吃力不讨好的事。

  • 解决方法:

  1. 使用pyheatmap
from pyheatmap.heatmap import HeatMap
import numpy as np
import numpy as np
import pandas as pd
import cv2
import matplotlib.pyplot as plt
import seaborn as sns
import numpy as np
import matplotlib.pyplot as plt

# 需要修改的路径。。。。。。。。。。
file_path = 'C:/Users/yaohua-win/Desktop/A.xlsx'

f = pd.read_excel(file_path)
f = np.array(f)

f[:, 0:2] = f[:, 0:2] / 100  # 控制输出分辨率,前面为保留精度没有舍弃小数点

print('f:', f)
list_data=[]

len_data = len(f)

for i in range(len_data):
    list_data.append([int(f[i][0]*10),int(f[i][1]*10),1])

    if i % 100 == 0:
        print('处理进度:', i/len_data)

# Just testing
#t = []
#for i in range(100):
#    t.append([i, i, i*5])
#list_data = t

#data = [[int(i[0]*10),int(i[1]*10),i[2]] for i in f]
#data = [[1,1,2],[2,2,2]]
heat = HeatMap(list_data)
heat.clickmap(save_as="1.png") #点击图
heat.heatmap(save_as="heatmap.png") #热图
  1. 使用matplotpib
    每个点attech了不同的数值,而且没有被插值
    先放效果图,适合你的需求再copy节省时间。
    在这里插入图片描述
import numpy as np
import matplotlib.pyplot as plt
import matplotlib as mpl
import matplotlib.colors as colors
import matplotlib.cbook as cbook

N = 100
X, Y = np.mgrid[-3:3:complex(0, N), -2:2:complex(0, N)]

Z = np.ones((N, N))
Z[50][50] = 100

# Z = []
for i in range(1, 100):
    Z[i][i] = i*2.5
# Z = np.array(Z)

fig, ax = plt.subplots(nrows=1, ncols=1)

cmap = mpl.colors.ListedColormap(['red', 'green', 'blue', 'cyan'])
cmap.set_over('0.25')
cmap.set_under('0.75')

cmap = mpl.cm.cool

# pcm = ax[0].pcolor(X, Y, Z,
pcm = ax.pcolor(X, Y, Z,
                norm=colors.LogNorm(vmin=Z.min(), vmax=Z.max()),
                # cmap='PuBu_r', shading='auto'
                cmap=cmap, shading='auto'
                )

# fig.colorbar(pcm, ax=ax[0], extend='max')
fig.colorbar(pcm, ax=ax, extend='max')

plt.show()

如果要修改不同数值的颜色,请点击参考这里

参考

1.matplot heatmap tutorials

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Python可视化热图的方法有多种,其中一种是使用seaborn库的heatmap()函数。该函数可以用来展示数据表中多个特征之间的相似度。以下是一个简单的示例代码: ```python import seaborn as sns import numpy as np import pandas as pd import matplotlib.pyplot as plt # 创建数据 data = np.random.rand(10, 10) # 绘制热图 sns.heatmap(data) # 显示图形 plt.show() ``` 在这个示例中,我们首先导入了seaborn库,并生成了一个随机的10x10的数据表。然后,我们使用heatmap()函数绘制热图,该函数会根据数据表中的数值来给不同的单元格上色。最后,我们使用plt.show()函数显示了图形。 你也可以根据需要调整heatmap()函数的参数,例如设置颜色映射、添加标签等。具体的参数说明可以参考seaborn官方文档中的API参数及地址。 #### 引用[.reference_title] - *1* [python可视化进阶---seaborn1.9 时间线图表、热图 tsplot() / heatmap()](https://blog.csdn.net/qq_42554007/article/details/82627066)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Python数据可视化seaborn(七) -- 时间线图表、热图](https://blog.csdn.net/d1240673769/article/details/118721207)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [python如何实现可视化热力图](https://blog.csdn.net/xuange01/article/details/103395327)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值