百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

文科生自学Python-用Seaborn/Plotly画热力图

off999 2024-12-10 19:20 22 浏览 0 评论

--世界上只有一种真正的英雄主义,就是看清生活的真相之后依然热爱生活,学习编程成就更好的自己--

Python语言简洁生动,特别适合文科生学习入门IT世界,用几十行代码就能够做一个完整的爬虫脚本,开发效率杠杠的!短时间内即可解决工作和学习中碰到的各种棘手问题。(本人外语专业毕业,机缘巧合爱上编程,自学道路曲曲折折,痛并快乐!)在这里总结一下自学Python遇到的难点和重点,分享码过的代码和要点总结,希望能够给初学者一点启示和鼓励,同时愿意结交更多大神交流有助提升自己的水平。

今天分享一下大名鼎鼎的热力图-heatmap,主要使用Seaborn资源库来制图演示,最后也用Plotly做一个简单展示和对比,大家都知道热力图可以生动对比不同数据样本数值大小情况,下面选取的案例样本还是Plotly内置的世界人口数据集

1.调包并抽取几个国家生成一个特定的数据集合,方便后续制图和演示:

#import plotly to get the datasets
import plotly.graph_objects as go
import plotly_express as px
#import seaborn to draw heatmap
import matplotlib.pyplot as plt
import seaborn as sns
import pandas as pd
#Get a dataset of different countries
df = px.data.gapminder().query("country == ['France','Germany','Italy','Canada','Spain','Thailand','Argentina']") #'Japan'
df["life"] = df["lifeExp"].astype(int)
df["pop-KW"] = (df["pop"]/10000000).astype(int) #GGet pop 1000W
display(df)

选取了法国,德国,意大利,西班牙,加拿大,泰国和阿根廷并查看:

2.在制图之前加工数据成为交叉二维表,方便直接生成热力图

#get the data into a proper pivot to draw heatmap
pop_life_heatmap = df.pivot("country", "year", "life")
display(pop_life_heatmap)

通过pivot方法得到交叉表(抽取寿命长短数据),一般横向对应的是X轴,纵向对应的是Y轴,表格显示不同国家在不同年代国民平均寿命情况:

3.通过sns.heatmap函数直接绘制热力图

#https://seaborn.pydata.org/generated/seaborn.heatmap.html?highlight=fmt#seaborn.heatmap
fig=sns.heatmap(pop_life_heatmap,annot=False,fmt="d",cmap="RdBu_r")
fig

生成的热力图略小,考虑调整图像大小:

4.添加参数f, ax = plt.subplots(figsize=(x, x))调整图像大小

#https://seaborn.pydata.org/tutorial/color_palettes.html#tools-for-choosing-color-palettes
f, ax = plt.subplots(figsize=(15, 10)) #set the size of heatmap
fig=sns.heatmap(pop_life_heatmap,annot=False,fmt="d",linewidths=0.5,cmap="RdBu_r") #
fig

考虑在每个色块备注上数值,方便更具体的对比:

5.调整参数选项annot=True即可显示数值

#https://seaborn.pydata.org/tutorial/color_palettes.html#tools-for-choosing-color-palettes
f, ax = plt.subplots(figsize=(15, 10)) #set the size of heatmap
fig=sns.heatmap(pop_life_heatmap,annot=True,fmt="d",linewidths=0.5,cmap="RdBu_r") #
fig

是不是感觉有点专业的味道了,而且直观对比不同国家寿命情况:

6.还可变换不同颜色主题风格,且可以调整色块间距

#https://seaborn.pydata.org/tutorial/color_palettes.html#tools-for-choosing-color-palettes
f, ax = plt.subplots(figsize=(15, 10)) #set the size of heatmap
fig=sns.heatmap(pop_life_heatmap,annot=True,fmt="d",linewidths=2,cmap="viridis") #Spectral viridis
fig

参数linewidths可以调整色块间距大小,Seaborn提供了多个不同颜色主题风格,相关链接参考如下:

https://seaborn.pydata.org/tutorial/color_palettes.html#tools-for-choosing-color-palettes:

7.给热力图添加标题

#https://seaborn.pydata.org/tutorial/color_palettes.html#tools-for-choosing-color-palettes
f, ax = plt.subplots(figsize=(15, 10)) #set the size of heatmap
fig=sns.heatmap(pop_life_heatmap,annot=True,fmt="d",linewidths=0.5,cmap="YlOrBr") #viridis YlOrBr
#set title for it
fig.set_title(label="Heatmap of Pop LifeEXP from different Countries",fontdict = {"fontsize":11})
#set position for the xaxis ticks
fig

添加参数set_title即可:

8.把年份标记信息显示调整到上方

#https://seaborn.pydata.org/tutorial/color_palettes.html#tools-for-choosing-color-palettes
f, ax = plt.subplots(figsize=(15, 10)) #set the size of heatmap
fig=sns.heatmap(pop_life_heatmap,annot=True,fmt="d",linewidths=0.5,cmap="Spectral") #viridis YlOrBr
#set title for it
fig.set_title(label="Heatmap of Pop LifeEXP from different Countries",fontdict = {"fontsize":11})
#set position for the xaxis ticks
fig.xaxis.set_ticks_position("top") 
fig

添加和设置参数xaxis.set_ticks_position即可:

看到这里是不是感叹Seaborn真的很给力啊!!!几行代码就能绘制特别优雅的热力图,能够直观展示数据间的大小关系,接下来简单讲一下如何用Plotly实现吧:

9.同样使用刚刚的数据集合

#draw heatmap with plotly
pop_life_heatmap = df.pivot("country", "year", "life")
display(pop_life_heatmap)

查看处理好的交叉表:

10.通过imshow制图函数生成热力图

#draw heatmap with plotly 
#https://plotly.com/python/imshow/
fig = px.imshow(pop_life_heatmap,labels=dict(x="Year", y="Country", color="LifeExp"))
fig.show()

得到的热力图看起来也不错,还能进行一定的交互:

11.同样考虑改变一下颜色主题风格

fig = px.imshow(pop_life_heatmap,color_continuous_scale='RdBu_r',labels=dict(x="Year", y="Country", color="LifeExp"))
fig.show()

大家看到这里也赶紧动手试试吧!!

END

我为人人,人人为我!!欢迎大家关注,点赞和转发!!!

~~人生不是赛场,梦想不容退场~~不断努力学习蜕变出一个更好的自己,不断分享学习路上的收获和感悟帮助他人成就自己!!!

相关推荐

磁力种子(磁力种子搜索器怎么用)

BT的种子是指在BitTorrent文件分享协议中的一个文件或者目录,其中包含有一个或多个文件的元数据,例如文件名、大小、哈希值等信息。一个种子文件可以看做是一个索引,用来描述一个或多个文件的组成和布...

app store直接下载(app store直接下载软件)
  • app store直接下载(app store直接下载软件)
  • app store直接下载(app store直接下载软件)
  • app store直接下载(app store直接下载软件)
  • app store直接下载(app store直接下载软件)
windows图片查看器无法显示此图片

是因为没有正确配置Windows颜色系统默认设备文件造成的,解决该问题的具体步骤是:打开控制面板,查看方式选择“大图标”,单击打开“颜色管理”对话框,单击选中“高级”选项卡,将Windows颜色系统设...

ghost xp下载g(ghost Xp下载16)
  • ghost xp下载g(ghost Xp下载16)
  • ghost xp下载g(ghost Xp下载16)
  • ghost xp下载g(ghost Xp下载16)
  • ghost xp下载g(ghost Xp下载16)
深度技术的win7系统怎么样(深度技术win7系统怎么安装教程)

所谓的纯净的win7系统应该说的就是原版的win7系统,相对于Ghost版的系统来说,原版的win7系统是微软发布的未经过第三方修改过的纯净版系统,安装好后,它所有的功能和软件都是微软官方的,不会添加...

电脑怎么安全模式开机(电脑怎么安全模式开机启动)

电脑开机后进入安全模式的步骤如下:重启电脑:在开机时,狂按F8键,即可进入启动菜单选择界面。选择安全模式:在启动菜单选择界面中,可以看到三个版本的安全模式可以选择,方向键上下调整,然后按下回车键即可。...

win10企业版长期服务版(win10企业版 长期服务版)

Windows10企业版和企业长期服务版是微软为企业用户提供的两个版本,二者主要区别如下:1.版本周期不同。企业版(Enterprise)每年更新两次,每个版本的支持期限仅为18个月,而企业长期服...

mercury管理页面网址(mercury设置网址是什么)

要进入mercury路由器的管理页面,首先需要将电脑与路由器连接,确保网络连接正常。接着在浏览器中输入路由器的默认IP地址(通常为192.168.1.1),按下回车键。输入用户名和密码(默认用户名和密...

qq手机版官方(qq手机版官方免费下载安装)

z.qq.com可以通过以下方式登录手机QQ空间:1、使用手机登录手机腾讯网3g.qq.com,点击“空间”,根据提示QQ号码和QQ密码就可以登录;2、通过手机直接输入手机QQ空间网址z.qq.co...

打印机驱动安装不了10个方法
  • 打印机驱动安装不了10个方法
  • 打印机驱动安装不了10个方法
  • 打印机驱动安装不了10个方法
  • 打印机驱动安装不了10个方法
w7旗舰版系统怎么恢复出厂设置啊

方法一:1、左键单击任务栏开始按钮2、在启动项菜单右侧找到“控制面板”并左键单击3、在打开的界面中找到“区域和语言”选项并左键单击4、在弹出窗口中选择“键盘和语言”,在“选择显示语言”下...

ubuntu下载安装(Ubuntu下载安装包)

要在Ubuntu上从官方网站下载和安装Evolution,您可以按照以下步骤进行操作:1.打开您的网页浏览器,访问Ubuntu的官方网站:https://ubuntu.com。2.点击页面顶部的“...

苹果强制恢复出厂设置(苹果强制恢复出厂设置密码忘记了)
  • 苹果强制恢复出厂设置(苹果强制恢复出厂设置密码忘记了)
  • 苹果强制恢复出厂设置(苹果强制恢复出厂设置密码忘记了)
  • 苹果强制恢复出厂设置(苹果强制恢复出厂设置密码忘记了)
  • 苹果强制恢复出厂设置(苹果强制恢复出厂设置密码忘记了)
win7补丁目录(windows补丁目录)
  • win7补丁目录(windows补丁目录)
  • win7补丁目录(windows补丁目录)
  • win7补丁目录(windows补丁目录)
  • win7补丁目录(windows补丁目录)
联想显示器售后服务电话(lenovo人工客服24小时)

联想显示器保修期限在1~2年之内,一,联想“三包”服务承诺联想按国家有关部门颁布的《微型计算机商品修理更换退货责任规定》(以下称“三包”规定)中的内容和范围,向用户提供“三包”服务。联想承担法定“...

取消回复欢迎 发表评论: