Redian新闻
>
丢掉Excel,手把手教你用Python做可视化数据,还能任意调节动画丝滑度

丢掉Excel,手把手教你用Python做可视化数据,还能任意调节动画丝滑度

公众号新闻
Pine 发自 凹非寺
量子位 | 公众号 QbitAI

数据可视化动画还在用Excel做?

现在一个简单的Python包就能分分钟搞定!

而且生成的动画也足够丝滑,效果是酱紫的:

这是一位专攻Python语言的程序员开发的安装包,名叫Pynimate

目前可以直接通过PyPI安装使用。

使用指南

想要使用Pynimate,直接import一下就行。

import pynimate as nim
输入数据后,Pynimate将使用函数Barplot()来创建条形数据动画。

而创建这种动画,输入的数据必须是pandas数据结构(如下),其中将时间列设置为索引,换句话说索引代表的是自变量。

time, col1, col2, col3
2012 1 2 1
2013 1 1 2
2014 2 1.5 3
2015 2.5 2 3.5

具体的代码形式如下:

import pandas as pd
df = pd.read_csv('data'csv').set_index('time')

比如要处理具体的数据,写成代码应该是这样子的。

df = pd.DataFrame(
{
"time": ["1960-01-01", "1961-01-01", "1962-01-01"],
"Afghanistan": [1, 2, 3],
"Angola": [2, 3, 4],
"Albania": [1, 2, 5],
"USA": [5, 3, 4],
"Argentina": [1, 4, 5],
}
).set_index("time")

此外,要制作条形数据动画,Barplot还有三个必需的参数得注意:data、time_format和ip_freq(Interpolation frequency)

data就是表格的数据,这里也就不再赘述。

time_format是指数据索引的时间日期格式,一般为:”%Y-%m-%d”。

最后是ip_freq,它是制作动画中比较关键的一步,通过线性插值使动画更加流畅丝滑。

一般来说,并不是所有的原始数据都适合做成动画,现在一个典型的视频是24fps,即每秒有24帧。

举个栗子🌰,下面这个表格中的数据只有三个时间点,按理说只能生成3帧视频,最终动画也只有3/24秒。

time, col1, col2
2012 1 3
2013 2 2
2014 3 1

这时候,ip_freq插值(线性)就开始发挥作用了,如果插值是一个季度,则得出的数据就变成了这样:

time     col1  col2
2012-01-01 1.00 3.00
2012-04-01 1.25 2.75
2012-07-01 1.50 2.50
2012-10-01 1.75 2.25
2013-01-01 2.00 2.00
2013-04-01 2.25 1.75
2013-07-01 2.50 1.50
2013-10-01 2.75 1.25
2014-01-01 3.00 1.00

具体的插值时间间隔为多久,则要视具体的数据而定,一般绘制大数据时,设置为ip_freq = None。

至此,就能生成数据动画了,完整代码如下所示:

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

df = pd.DataFrame(
{
"time": ["1960-01-01", "1961-01-01", "1962-01-01"],
"Afghanistan": [1, 2, 3],
"Angola": [2, 3, 4],
"Albania": [1, 2, 5],
"USA": [5, 3, 4],
"Argentina": [1, 4, 5],
}
).set_index("time")

cnv = nim.Canvas()
bar = nim.Barplot(df, "%Y-%m-%d", "2d")
bar.set_time(callback=lambda i, datafier: datafier.data.index[i].year)
cnv.add_plot(bar)
cnv.animate()
plt.show()

这是插值为两天,生成的动画效果。

最后还有一个问题,那就是保存动画,有两个格式可以选择:gif或者mp4。

保存为动图一般使用:

cnv.save("file", 24, "gif")

若要保存为mp4的话,ffmpeg是个不错的选择,它是保存为mp4的标准编写器。

 pip install ffmpeg-python

或者:

conda install ffmpeg

当然,同样也可以使用Canvas.save()来保存。

cnv.save("file", 24 ,"mp4")

作者介绍

julkar9,Python/Flutter 开发人员,研究的方向为数据分析与可视化

小哥表示,Pynimate还会不断更新,目前正在接受大家的反馈,之后还会上线等值区域图等功能。

他还开发了一个应用程序:Chatmetry,同样也与数据统计有关,是一个用于创建whatsapp聊天统计数据的机器人应用程序。

这个程序可以从导出的聊天中生成各种统计信息,同时支持个人和群组聊天,并且是完全离线的,既不会保存也不会共享。

传送门:
https://julkaar9.github.io/pynimate/

百度研究院、阿里达摩院、量子位智库

年度十大科技报告

总结2022,预见2023。来自百度研究院、阿里达摩院和量子位智库的年度十大科技报告均已发布,点击下方图片即可跳转查看。

百度研究院

阿里达摩院

量子位智库


点这里👇关注我,记得标星哦~

一键三连「分享」、「点赞」和「在看」

科技前沿进展日日相见 ~ 


微信扫码关注该文公众号作者

戳这里提交新闻线索和高质量文章给我们。
相关阅读
德国队还有戏吗?兔年新春聚会多?收藏这份保姆级攻略,手把手教你稳占C位!仙桃学术 | 生信怎么加湿实验?手把手教你4+干湿结合零代码复现不花一毛钱,手把手教你专柜千元换头术!就是这么牛!手把手教你看懂芯片行业:从交大热能系毕业,到硅谷芯片大厂总监手把手教你在伦敦挑居住区!满足这6大要素的才宜居!仅剩一席|三周掌握Python, SQL, R, Excel, VBA等必备工具疫苗一针大病一场【首发】一目可视完成数千万元天使轮融资,瞄准医学可视化构造生物医学知识库在澳洲报税少不了,手把手教你在澳洲申请税号​!一起薅羊毛的快乐!手把手教你订阅乐高杂志:一年5期都免费两天赚1w,用Python接私活的一些技巧油烟机都不用开!肉这样蒸着吃比炒更香,手把手教你5种家常做法干货!休斯顿超市牛排种类、等级、烹饪方法,手把手教你在家做出多汁嫩牛排这个占数学试卷一半分的思维能力,手把手教你怎么启蒙!【步骤】微信全面支持注册第二个账号:手把手教你搞定资本家牢狱管理打工人跳楼自杀爆!IKEA赔款2425万美金,手把手教你理赔;美国十大生活最贵城市,加州占三席!5分钟搞定春日编发,手把手教会!App“自动扣费”?手把手教你把钱要回来!达拉斯超市牛排种类/等级/烹饪方法,手把手教你在家做牛排,比餐馆还好吃!《流浪2》《中国乒乓》等一大波春节档华语电影上映!而我们恰好有$14.5的半价电影票!可用于任意Hoyts任意电影【更新】堪培拉留学新生指南:手把手教你从行李准备,国内上飞机,抵澳,到家躺下完全攻略!还包括入关,填入境卡,买车票哦~全新4+干湿结合套路文章,手把手教你单基因泛癌分析想吃腊味不用买!咸香鲜美有嚼劲,手把手教你做,比外面卖的好吃100倍~[快来] Costco黑卡免120刀年费!十余年来最大力度!手把手教你怎么薅这波羊毛!手把手教你注册海外Apple IDChatGPT版Excel?北大ChatExcel动动嘴皮子就把表格改完了3月1日开始报税了,手把手教你在新加坡如何交税作品媲美《哈利波特》的世界级文学大师,手把手教孩子创意写作!有了这 5 个自动化运维场景,让你用 Python 写脚本更爽!一个秘密攻略 | 手把手教你用积分兑换中美机票!表中贵族,认知与实际的偏差DC超市牛排种类/等级/烹饪方法,手把手教你在家做牛排,比餐馆还好吃!
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。