news 2026/5/13 14:32:56

基于matplotlib轻松绘制漂亮的表格

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
基于matplotlib轻松绘制漂亮的表格

1 简介

matplotlib作为数据可视化的强力工具,可以帮助我们自由创作各式各样的数据可视化作品,其中matplotlib.pyplot.table模块就专门用于绘制「表格」,但是由于参数复杂,且默认样式单一简陋,想基于它绘制出美观的表格需要花费不少功夫。

而我最近发现的一个基于matplotlib的第三方库plottable,用它来生成数据表格图既简单又美观

2 基于plottable绘制漂亮的表格

使用pip install plottable完成安装后,我们先从一个简单的例子了解其基础的使用方式:

2.1 从简单例子出发

plottable的基础使用很简单,在已有数据框的基础上,直接调用plottable中的Table模块即可:

渲染出的表格图如下:

2.2 plottable的常用方法

了解到plottable的基础用法后,接下来我们来学习如何添加一些常用参数来对表格进行美化:

2.2.1 控制表格奇数偶数行底色

通过在Table()中设置参数odd_row_coloreven_row_color,我们可以传入matplotlib中合法的色彩值进行表格奇数偶数行底色的设置:

2.2.2 控制表头单元格与数据单元格样式

通过Table()中的参数col_label_cell_kwcell_kw,我们可以分别对表头区域单元格、数据区域单元格进行样式设置,接受matplotlib.patches.Rectangle全部可用参数,例如:

2.2.3 调节单元格文字样式

通过参数textprops我们可以对全部单元格的文字样式进行控制:

2.2.4 配置行分割线

通过bool型参数col_label_dividerfooter_dividerrow_dividers可以分别设置是否为表头、表格尾部、数据行绘制分割线:

而通过参数col_label_divider_kwfooter_divider_kwrow_divider_kw则可以分别控制各个部分分割线的样式,支持plt.plot中全部参数:

2.2.5 基于ColDef的列样式细粒度设置

plottable中最强大的地方在于,其通过配置由plottable.ColDef对象列表构成的column_definitions参数,可细粒度地对每一列进行自由的样式定义,其中每个ColDef()对象通过参数name与列名进行对应,常见的用法有:

  • 分别设置不同字段的宽度比例系数

以每列的默认宽度为1,可以分别为不同列调整宽度:

  • 分别设置不同字段的文本对齐方式

每个ColDef对象都可设置textprops参数,基于此可以实现为不同字段定义水平对齐方式:

  • 分别为不同字段设置数值色彩映射

通过为ColDef设置参数cmaptext_cmap,我们可以分别基于对应列的数值,对其单元格底色或字体颜色进行值映射:

  • 为字段创建分组展示

通过为若干个ColDef设置相同的group参数,我们可以为具有相同group参数的字段添加分组标识:

  • 为指定字段绘制列边框

通过为ColDef设置参数border,我们可以决定如何绘制不同字段的列边框:

除了本文所述的部分功能外,plottable还有很多高级进阶的使用方法,譬如单元格图片渲染、自定义单元格绘制内容等,下面的几个例子就是基于plottable创作的:

❝ https://plottable.readthedocs.io/en/latest/example_notebooks/wwc_example.html

❝ https://plottable.readthedocs.io/en/latest/example_notebooks/bohndesliga_table.html

❝ https://plottable.readthedocs.io/en/latest/example_notebooks/plot_example.html

❝ https://plottable.readthedocs.io/en/latest/example_notebooks/heatmap.html

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/13 14:31:26

pandas中基于范围条件进行表连接

表连接是我们日常开展数据分析过程中很常见的操作,在pandas中基于join()、merge()等方法,可以根据左右表连接依赖字段之间对应值是否相等,来实现常规的表连接。但在有些情况下,我们可能需要基于一些“特殊”的条件匹配&#xff0c…

作者头像 李华
网站建设 2026/5/11 23:51:48

Open-AutoGLM跨地域部署实战(3大典型场景+完整配置模板)

第一章:Open-AutoGLM 广域网访问配置在部署 Open-AutoGLM 服务后,若需实现广域网(WAN)访问,必须对网络策略、端口映射及安全机制进行合理配置。默认情况下,服务仅监听本地回环地址,无法被外部网…

作者头像 李华
网站建设 2026/5/13 14:31:38

django基于Python网络爬虫的电子产品信息查询可视化系统vue

文章目录 系统截图项目简介大数据系统开发流程主要运用技术介绍爬虫核心代码展示结论源码文档获取定制开发/同行可拿货,招校园代理 :文章底部获取博主联系方式! 系统截图 django基于Python网络爬虫的电子产品信息查询可视化系统vue 项目简介 本次…

作者头像 李华
网站建设 2026/5/10 11:52:43

计算机毕业设计springbootKTV点歌系统 基于 SpringBoot 的云端 KTV 智能点歌平台 融合 SpringBoot 与 MySQL 的移动端 K 歌点播管理系统

计算机毕业设计springbootKTV点歌系统xr9awi04 (配套有源码 程序 mysql数据库 论文) 本套源码可以在文本联xi,先看具体系统功能演示视频领取,可分享源码参考。KTV 从纸质歌本到触摸屏,再到如今的手机扫码,点歌方式每一…

作者头像 李华
网站建设 2026/5/6 23:05:50

Excalidraw API接口详解:自动化生成图表的秘诀

Excalidraw API接口详解:自动化生成图表的秘诀 在技术文档撰写、系统架构设计和远程协作日益频繁的今天,一个常见的痛点浮出水面:如何快速、一致且美观地生成可视化图表?传统工具如 Visio 或 Lucidchart 虽然功能齐全&#xff0c…

作者头像 李华