Python利用pynimate實(shí)現(xiàn)制作動(dòng)態(tài)排序圖
數(shù)據(jù)可視化動(dòng)畫(huà)還在用 Excel 做?今天分享一個(gè)簡(jiǎn)單的 Python 包就能分分鐘搞定!
而且生成的動(dòng)畫(huà)也足夠絲滑,效果是醬紫的:

這是一位專(zhuān)攻 Python 語(yǔ)言的程序員開(kāi)發(fā)的安裝包,名叫Pynimate。
目前可以直接通過(guò)PyPI安裝使用。

使用指南
想要使用 Pynimate,直接import一下就行。
import pynimate as nim
輸入數(shù)據(jù)后,Pynimate將使用函數(shù)Barplot()來(lái)創(chuàng)建條形數(shù)據(jù)動(dòng)畫(huà)。
而創(chuàng)建這種動(dòng)畫(huà),輸入的數(shù)據(jù)必須是pandas數(shù)據(jù)結(jié)構(gòu)(如下),其中將時(shí)間列設(shè)置為索引,換句話說(shuō)索引代表的是自變量。
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')
比如要處理具體的數(shù)據(jù),寫(xiě)成代碼應(yīng)該是這樣子的。
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")
此外,要制作條形數(shù)據(jù)動(dòng)畫(huà),Barplot還有三個(gè)必需的參數(shù)得注意:data、time_format和ip_freq(Interpolation frequency)。
data就是表格的數(shù)據(jù),這里也就不再贅述。
time_format是指數(shù)據(jù)索引的時(shí)間日期格式,一般為:”%Y-%m-%d”。
最后是ip_freq,它是制作動(dòng)畫(huà)中比較關(guān)鍵的一步,通過(guò)線性插值使動(dòng)畫(huà)更加流暢絲滑。
一般來(lái)說(shuō),并不是所有的原始數(shù)據(jù)都適合做成動(dòng)畫(huà),現(xiàn)在一個(gè)典型的視頻是24fps,即每秒有24幀。
舉個(gè)栗子,下面這個(gè)表格中的數(shù)據(jù)只有三個(gè)時(shí)間點(diǎn),按理說(shuō)只能生成3幀視頻,最終動(dòng)畫(huà)也只有3/24秒。
time, col1, col2
2012 1 3
2013 2 2
2014 3 1
這時(shí)候,ip_freq插值(線性)就開(kāi)始發(fā)揮作用了,如果插值是一個(gè)季度,則得出的數(shù)據(jù)就變成了這樣:
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
具體的插值時(shí)間間隔為多久,則要視具體的數(shù)據(jù)而定,一般繪制大數(shù)據(jù)時(shí),設(shè)置為ip_freq = None。
至此,就能生成數(shù)據(jù)動(dòng)畫(huà)了,完整代碼如下所示:
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()
這是插值為兩天,生成的動(dòng)畫(huà)效果。

最后還有一個(gè)問(wèn)題,那就是保存動(dòng)畫(huà),有兩個(gè)格式可以選擇:gif或者mp4。
保存為動(dòng)圖一般使用:
cnv.save("file", 24, "gif")
若要保存為mp4的話,ffmpeg是個(gè)不錯(cuò)的選擇,它是保存為mp4的標(biāo)準(zhǔn)編寫(xiě)器。
pip install ffmpeg-python
或者:
conda install ffmpeg
當(dāng)然,同樣也可以使用Canvas.save()來(lái)保存。
cnv.save("file", 24 ,"mp4") 到此這篇關(guān)于Python利用pynimate實(shí)現(xiàn)制作動(dòng)態(tài)排序圖的文章就介紹到這了,更多相關(guān)Python動(dòng)態(tài)排序圖內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python按條件刪除Excel表格數(shù)據(jù)的方法(示例詳解)
本文介紹基于Python語(yǔ)言,讀取Excel表格文件,基于我們給定的規(guī)則,對(duì)其中的數(shù)據(jù)加以篩選,將不在指定數(shù)據(jù)范圍內(nèi)的數(shù)據(jù)剔除,保留符合我們需要的數(shù)據(jù)的方法,感興趣的朋友跟隨小編一起看看吧2024-08-08
Python 給某個(gè)文件名添加時(shí)間戳的方法
今天小編就為大家分享一篇Python 給某個(gè)文件名添加時(shí)間戳的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-10-10
python爬蟲(chóng)將js轉(zhuǎn)化成json實(shí)現(xiàn)示例
這篇文章主要為大家介紹了python爬蟲(chóng)將js轉(zhuǎn)化成json實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
Python常用模塊logging——日志輸出功能(示例代碼)
logging模塊是Python的內(nèi)置模塊,主要用于輸出運(yùn)行日志,可以靈活配置輸出日志的各項(xiàng)信息。這篇文章主要介紹了Python常用模塊logging——日志輸出的實(shí)例代碼,需要的朋友可以參考下2019-11-11
scipy.interpolate插值方法實(shí)例講解
這篇文章主要介紹了scipy.interpolate插值方法介紹,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-12-12
Python使用修飾器執(zhí)行函數(shù)的參數(shù)檢查功能示例
這篇文章主要介紹了Python使用修飾器執(zhí)行函數(shù)的參數(shù)檢查功能,結(jié)合具體實(shí)例形式分析了Python實(shí)現(xiàn)修飾器針對(duì)函數(shù)參數(shù)檢查的原理、步驟與相關(guān)操作技巧,需要的朋友可以參考下2017-09-09
python實(shí)現(xiàn)博客文章爬蟲(chóng)示例
簡(jiǎn)單的博客文章爬蟲(chóng),比較通用,因?yàn)榇蟛糠值木W(wǎng)站結(jié)構(gòu)都差不多,需要的朋友可以參考下2014-02-02
Python如何實(shí)現(xiàn)文本轉(zhuǎn)語(yǔ)音
文本轉(zhuǎn)語(yǔ)音,一般會(huì)用在無(wú)障礙開(kāi)發(fā)。下面介紹如何使用Python實(shí)現(xiàn)將文本文件轉(zhuǎn)換成語(yǔ)音輸出。跟著小編一起來(lái)看看吧。2016-08-08
解決jupyter notebook import error但是命令提示符import正常的問(wèn)題
這篇文章主要介紹了解決jupyter notebook import error但是命令提示符import正常的問(wèn)題,具有很好的參考2020-04-04

