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

【数据可视化】Python日历热力图calplot

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

很久没有更新了,本来不打算更新内容了,但是这一段时间持续会用到一些以前的知识内容,PowerBI、Python和R都会涉及,有些特定的问题查资料、问ChatGPT都不能很有效的解决,最方便的还是看自己的历史文章,因为是自己写的,很容易就能够拿来使用。

所以基于此还是打算后面会继续更新内容,尽量让每一个板块最后都能形成体系,方便查阅和使用。打算更新的内容是PowerBI、数据可视化、分析思维模型、机器学习四个方向,没有固定的顺序,但最后会查漏补缺形成一个整体。

今天从一个可视化的内容开始回归。因为有使用需求,但是网上查了很多资料都很简单,没有达到使用的需求,于是结合官方文档,把自己能够想到的需求都使用案例完整展示一遍。是关于日历可视化的一个需求,目标很简单,按照每天一个单元格,每周一个维度,把一年的数据连城整体,可以直观的从日期的维度看到数据的趋势。

官方的链接和案例效果如下,有更细致的需求可以去看文档↓

https://calplot.readthedocs.io/en/latest/

可使用的参数也挺多,这里只列出来做参考↓

calplot.calplot(data, 
                how='sum', 
                yearlabels=True, 
                yearascending=True, 
                yearlabel_kws=None, 
                subplot_kws=None, 
                gridspec_kws=None, 
                figsize=None, 
                fig_kws=None, 
                colorbar=None, 
                suptitle=None, 
                suptitle_kws=None, 
                tight_layout=True, 
                **kwargs)

数据格式很简单,一个日期列+一个数值列,日期列需要设置成Index,作用是可以提取日期和时间,精准的放在每个方块里面。值只需要一个字段,根据值的大小来显示颜色。这里有一个模拟的数据,下载地址和字段如下↓

https://linss.oss-cn-beijing.aliyuncs.com/Python/File/calplot_data.xlsx

【准备工作】

先导入相应的数据和包,除了calplot的主题包可能需要格外安装,其他都是常用的包↓

import os
os.chdir(r"C:\Users\wangf\Desktop")
import calplot
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
from matplotlib.font_manager import FontProperties
font_path = 'C:/WINDOWS/Fonts/MSYH.TTC'
my_font = FontProperties(fname=font_path)
plt.rcParams['font.sans-serif'] = ['SimHei']  # 设置中文字体为黑体
plt.rcParams['axes.unicode_minus'] = False  # 用来正常显示负号

这里因为后续需要用中文字符,就先把字体进行了设置,后续就不会报错了。然后接下来加载数据就行了。需要注意的是,要通过要把数据转化成series格式↓

df = pd.read_excel("calplot_data.xlsx")
df.set_index(df['date'],inplace = True)
df = df[['value']]
#将DataFrame的单列转换为Series,保留索引
series_data = df.squeeze()

【内置画图】

先简单画一个,大部分是内置参数,只需要传输数据即可↓

calplot.calplot(series_data)

通过edgecolor参数把边框去掉,然后使用cmap来映射系统的颜色,可以根据需求选择色系,代码和效果如下↓

calplot.calplot(series_data, 
                edgecolor=None, 
                cmap='RdGy_r')

使用figsize参数可以设置画布的大小↓

calplot.calplot(series_data, 
                edgecolor=None, 
                cmap='RdGy_r', 
                figsize=(16,9))

现在横坐标和纵坐标显示的是英文的星期和月份的缩写,可以通过daylabels和monthlabels两个参数设置自定义的显示名称,但需要主义的是,星期里面必须有7个值,月份里面必须12个值,代码和如下↓

calplot.calplot(series_data,
                edgecolor=None,
                figsize=(16,6),
                daylabels = ("周一","周二","周三","周四","周五","周六","周日"),
                monthlabels = ("1月","2月","3月","4月","5月","6月","7月","8月","9月","10月","11月","12月"),
                cmap='RdGy_r')

系统自带的颜色选项有166种,如下,可以根据需求自己选择,可以通过循环语句,展示所有的颜色,下面用部分颜色进行演示↓

color_list = ['Accent', 'Accent_r', 'Blues', 'Blues_r', 'BrBG', 'BrBG_r', 'BuGn', 'BuGn_r', 'BuPu', 'BuPu_r', 'CMRmap', 'CMRmap_r', 'Dark2', 'Dark2_r', 'GnBu', 'GnBu_r', 'Greens', 'Greens_r', 'Greys', 'Greys_r', 'OrRd', 'OrRd_r', 'Oranges', 'Oranges_r', 'PRGn', 'PRGn_r', 'Paired', 'Paired_r', 'Pastel1', 'Pastel1_r', 'Pastel2', 'Pastel2_r', 'PiYG', 'PiYG_r', 'PuBu', 'PuBuGn', 'PuBuGn_r', 'PuBu_r', 'PuOr', 'PuOr_r', 'PuRd', 'PuRd_r', 'Purples', 'Purples_r', 'RdBu', 'RdBu_r', 'RdGy', 'RdGy_r', 'RdPu', 'RdPu_r', 'RdYlBu', 'RdYlBu_r', 'RdYlGn', 'RdYlGn_r', 'Reds', 'Reds_r', 'Set1', 'Set1_r', 'Set2', 'Set2_r', 'Set3', 'Set3_r', 'Spectral', 'Spectral_r', 'Wistia', 'Wistia_r', 'YlGn', 'YlGnBu', 'YlGnBu_r', 'YlGn_r', 'YlOrBr', 'YlOrBr_r', 'YlOrRd', 'YlOrRd_r', 'afmhot', 'afmhot_r', 'autumn', 'autumn_r', 'binary', 'binary_r', 'bone', 'bone_r', 'brg', 'brg_r', 'bwr', 'bwr_r', 'cividis', 'cividis_r', 'cool', 'cool_r', 'coolwarm', 'coolwarm_r', 'copper', 'copper_r', 'cubehelix', 'cubehelix_r', 'flag', 'flag_r', 'gist_earth', 'gist_earth_r', 'gist_gray', 'gist_gray_r', 'gist_heat', 'gist_heat_r', 'gist_ncar', 'gist_ncar_r', 'gist_rainbow', 'gist_rainbow_r', 'gist_stern', 'gist_stern_r', 'gist_yarg', 'gist_yarg_r', 'gnuplot', 'gnuplot2', 'gnuplot2_r', 'gnuplot_r', 'gray', 'gray_r', 'hot', 'hot_r', 'hsv', 'hsv_r', 'inferno', 'inferno_r', 'jet', 'jet_r', 'magma', 'magma_r', 'nipy_spectral', 'nipy_spectral_r', 'ocean', 'ocean_r', 'pink', 'pink_r', 'plasma', 'plasma_r', 'prism', 'prism_r', 'rainbow', 'rainbow_r', 'seismic', 'seismic_r', 'spring', 'spring_r', 'summer', 'summer_r', 'tab10', 'tab10_r', 'tab20', 'tab20_r', 'tab20b', 'tab20b_r', 'tab20c', 'tab20c_r', 'terrain', 'terrain_r', 'turbo', 'turbo_r', 'twilight', 'twilight_r', 'twilight_shifted', 'twilight_shifted_r', 'viridis', 'viridis_r', 'winter', 'winter_r']
fig, axs = plt.subplots(10, 1, figsize=(6, 20))
for i, cor in enumerate(color_list[:10]):
    ax = axs[i]
    calplot.yearplot(series_data,
                    edgecolor=None,
                    ax=ax,
                    daylabels=("周一", "周二", "周三", "周四", "周五", "周六", "周日"),
                    monthlabels=("1月", "2月", "3月", "4月", "5月", "6月", "7月", "8月", "9月", "10月", "11月", "12月"),
                    cmap=cor)
    ax.set_title(cor, fontsize=16, pad=10)
plt.tight_layout()
plt.show()

【自定义颜色】

当然如果对系统的配色不满意,可以自己来自定义颜色,需要加载matplotlib里面颜色的包↓

import matplotlib.colors as mcolors
from matplotlib.colors import LinearSegmentedColormap
# 创建自定义颜色映射
custom_colors = ['#b52410', '#bfb43b', '#30ad1a']
num_colors = len(custom_colors)
colors = [mcolors.to_rgba(color) for color in custom_colors]
cmap = LinearSegmentedColormap.from_list('custom_cmap', colors, N=num_colors)
# 重新绘制颜色修改后的日历图
calplot.calplot(series_data,
                edgecolor=None,
                figsize=(16,6),
                daylabels = ("周一","周二","周三","周四","周五","周六","周日"),
                monthlabels = ("1月","2月","3月","4月","5月","6月","7月","8月","9月","10月","11月","12月"),
                cmap=cmap)

上面自定义了红黄蓝三个颜色,效果如下↓

可以看到,效果还可以,但是有一个不足是三种颜色是固定的,而不是上面系统中的渐变色,这就需要继续操作一下。

# 创建自定义渐变色映射
colors = [(0, '#b52410'), (0.5, '#ffffff'), (1, '#30ad1a')]
cmap = LinearSegmentedColormap.from_list('custom_cmap', colors)


# 绘制日历图,并使用自定义的渐变色映射
calplot.calplot(series_data,
                edgecolor=None,
                figsize=(16,6),
                daylabels = ("周一","周二","周三","周四","周五","周六","周日"),
                monthlabels = ("1月","2月","3月","4月","5月","6月","7月","8月","9月","10月","11月","12月"),
                cmap=cmap)

最终得到了我们想要的效果。

链接是我使用PowerBI整合的历史文章,按类型分类,可以根据需求查询:Microsoft Power BI

End

相关推荐

下载百度软件(下载百度软件商店安装不了)
  • 下载百度软件(下载百度软件商店安装不了)
  • 下载百度软件(下载百度软件商店安装不了)
  • 下载百度软件(下载百度软件商店安装不了)
  • 下载百度软件(下载百度软件商店安装不了)
dell笔记本电脑如何重装系统
  • dell笔记本电脑如何重装系统
  • dell笔记本电脑如何重装系统
  • dell笔记本电脑如何重装系统
  • dell笔记本电脑如何重装系统
google浏览器安卓版(google浏览器安卓版华军软件园)
  • google浏览器安卓版(google浏览器安卓版华军软件园)
  • google浏览器安卓版(google浏览器安卓版华军软件园)
  • google浏览器安卓版(google浏览器安卓版华军软件园)
  • google浏览器安卓版(google浏览器安卓版华军软件园)
改ip地址的软件有哪些(改ip的软件真的有用吗)

没有绝对好用的IP修改器,ip修改器只有合适自己的才是最好的。因为IP修改器的使用环境不一样,每个ip修改器功能和特点不同,自己用途和范围选择合适的。比如,有些ip修改器适合修改ip地址,有的IP修改...

台式机安装系统步骤(绝尘侠台式机如何u盘安装系统)

中柏EZbookA13使用U盘重装系统:1、将u盘制作成【u启动u盘启动盘】,接着前往相关网站下载win系统存到u盘启动盘,重启电脑等待出现开机画面按下启动快捷键,选择u盘启动进入到主菜单,选取“【...

台式电脑w7怎么升级w10(台式机win7升级win10)

Win7不够8G内存怎么升级到win10。朋友也就是说你现在在使用win7系统。内存不够8G那就是4G的呀。Windows10最低配置的内存就是4G。所以说你要把windows7升级为window...

电脑怎么下载百度(笔记本电脑怎么下载百度)

电脑下载浏览器步骤如下1.打开电脑浏览器,搜索想要下载的电脑版的浏览器,打开官网2.进入官网,点击立即下载3.出现新建下载任务图标,点击下载,下载安装包4.下载完毕,点击打开5.进入安装界面,点击安装...

gho怎么安装系统(gho怎么重装系统)
  • gho怎么安装系统(gho怎么重装系统)
  • gho怎么安装系统(gho怎么重装系统)
  • gho怎么安装系统(gho怎么重装系统)
  • gho怎么安装系统(gho怎么重装系统)
此电脑图标不见了怎么恢复(电脑中此电脑图标不见了怎么恢复)
此电脑图标不见了怎么恢复(电脑中此电脑图标不见了怎么恢复)

步骤/方式1系统版本:windows10系统  品牌型号:联想ThinkPad。 步骤:在桌面空白处点击鼠标右键选择个性化;步骤/方式2点击更改桌面图标。步骤/方式3勾选计算机。步骤/方式4如下所示,即可把“此电脑”图标显示在电脑桌面。...

2025-11-06 15:51 off999

电脑声卡驱动安装(电脑声卡驱动安装失败)
  • 电脑声卡驱动安装(电脑声卡驱动安装失败)
  • 电脑声卡驱动安装(电脑声卡驱动安装失败)
  • 电脑声卡驱动安装(电脑声卡驱动安装失败)
  • 电脑声卡驱动安装(电脑声卡驱动安装失败)
路由器wan口未连接如何处理(路由器wan口未连接是什么原因)

路由器wan口未连接的原因!出现WAN口未连接的情况,有以下2种常见的原因:1、路由器的WAN口没有与Moden(猫)、光猫、入户网线连接,并且路由器自动检测到了该问题而进行的提示2、路由器进行了...

阿里云国际站ECS:阿里云ECS如何提高网站的访问速度?

TG:@yunlaoda360引言:速度即体验,速度即业务在当今数字化的世界中,网站的访问速度已成为决定用户体验、用户留存乃至业务转化率的关键因素。页面加载每延迟一秒,都可能导致用户流失和收入损失。对...

高流量大并发Linux TCP性能调优_linux 高并发网络编程

其实主要是手里面的跑openvpn服务器。因为并没有明文禁p2p(哎……想想那么多流量好像不跑点p2p也跑不完),所以造成有的时候如果有比较多人跑BT的话,会造成VPN速度急剧下降。本文所面对的情况为...

性能测试100集(12)性能指标资源使用率

在性能测试中,资源使用率是评估系统硬件效率的关键指标,主要包括以下四类:#性能测试##性能压测策略##软件测试#1.CPU使用率定义:CPU处理任务的时间占比,计算公式为1-空闲时间/总...

Linux 服务器常见的性能调优_linux高性能服务端编程

一、Linux服务器性能调优第一步——先搞懂“看什么”很多人刚接触Linux性能调优时,总想着直接改配置,其实第一步该是“看清楚问题”。就像医生看病要先听诊,调优前得先知道服务器“哪里...

取消回复欢迎 发表评论: