Python3,5行代码,生成自动排序动图,这操作不比Excel香?

本文介绍了如何使用Python库pynimate来生成动态排序图,通过几行代码展示了从安装到实现动图的全过程。文章通过一个小故事引入,详细解释了pynimate的功能和使用方法,包括安装库和编写示例代码,最后展示了运行效果。

1、引言

小屌丝:鱼哥,听说你的excel段位又提升了?
小鱼:你这是疑问的语气?
小屌丝:没有~ 吧…
小鱼:是没有,没有没有吧?
小屌丝:这… 正好我有一个难点,想请教你。
小鱼:那你说吧。
小屌丝:你制作一个动态排序图吗?
小鱼:这有何难,内容是啥,样式是啥?
小屌丝:就是这样的。

在这里插入图片描述

小鱼:就这??
小屌丝:嗯呢,就这。
小鱼:这有何难, 分分钟的事。
在这里插入图片描述

小屌丝:鱼哥,那看你的了。

2、代码实战

2.1 pynimate介绍

说到排序动图的制作, 我们第一反应就是 Excel 或者PPT。
因为这Excel的功能太强大,而且普及率非常高。

但是,今天,我们不用Excel来制作动态排序图,
而是用 python的一个很奈斯的库:pynimate。

可以说,pynimate就是为了动态可视化而生了。

小屌丝:这话说的,貌似没毛病。

只要区区几行代码,就可以实现上图中动态排序的效果。

小屌丝:听这话,应该很简单的样子。

2.2 pynimate安装

涉及到第三方库,肯定就需要安装
老规矩,pip 安装

pip install pynimate

然后就是等待着安装。

其它安装方式,直接看这两篇:

2.3 代码示例

代码展示

# -*- coding:utf-8 -*-
# @Time   : 2023-02-12
# @Author : Carl_DJ

'''
实现功能:
    pynimate 实现动态排序图
'''

import pynimate as nim
import  pandas as pd
from matplotlib import pylab as plt

#设置数据(只是假数据,不代表实际情况)
data = pd.DataFrame(
    {
        "time": ["1998-01-01", "1999-01-01", "2000-01-01"],
        "changsha": [1, 2, 3],
        "wuhan": [2, 3, 4],
        "guangzhou": [1, 2, 5],
        "shanghai": [5, 3, 4],
        "beijing": [1, 4, 5],
    }
).set_index('time')

cnv =  nim.Canvas()
bar = nim.Barplot(data, "%Y-%m-%d", "2d")
bar.set_time(callback=lambda  i ,datafier:datafier.data.index[i].strftime("%b, %Y"))
cnv.add_plot(bar)
cnv.animate()
#展示效果图
plt.show()

#保存为gif格式
cnv.save("demo", 24, "gif")

运行效果
请添加图片描述

3、总结

看到这里,今天的分享差不多就该结束了。
小屌丝:鱼哥,这可以啊。比excel简单的太多了。
小鱼:低调低调,我一般也不随便展示实力。
在这里插入图片描述

我是小鱼

  • CSDN 博客专家;
  • 阿里云 专家博主;
  • 51CTO 博客专家;
  • 51认证讲师;
  • 金牌面试官&面试培训师;

关注我,带你学习更多更有趣的Python知识。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Carl_奕然

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值