丟掉Excel,手把手教你用Python做可視化數(shù)據(jù),還能任意調節(jié)動畫絲滑度
本文經(jīng)AI新媒體量子位(公眾號ID:QbitAI)授權轉載,轉載請聯(lián)系出處。
數(shù)據(jù)可視化動畫還在用Excel做?
現(xiàn)在一個簡單的Python包就能分分鐘搞定!
而且生成的動畫也足夠絲滑,效果是醬紫的:
這是一位專攻Python語言的程序員開發(fā)的安裝包,名叫Pynimate。
目前可以直接通過PyPI安裝使用。
使用指南
想要使用Pynimate,直接import一下就行。
而創(chuàng)建這種動畫,輸入的數(shù)據(jù)必須是pandas數(shù)據(jù)結構(如下),其中將時間列設置為索引,換句話說索引代表的是自變量。
具體的代碼形式如下:
比如要處理具體的數(shù)據(jù),寫成代碼應該是這樣子的。
此外,要制作條形數(shù)據(jù)動畫,Barplot還有三個必需的參數(shù)得注意:data、time_format和ip_freq(Interpolation frequency)。
data就是表格的數(shù)據(jù),這里也就不再贅述。
time_format是指數(shù)據(jù)索引的時間日期格式,一般為:”%Y-%m-%d”。
最后是ip_freq,它是制作動畫中比較關鍵的一步,通過線性插值使動畫更加流暢絲滑。
一般來說,并不是所有的原始數(shù)據(jù)都適合做成動畫,現(xiàn)在一個典型的視頻是24fps,即每秒有24幀。
舉個栗子??,下面這個表格中的數(shù)據(jù)只有三個時間點,按理說只能生成3幀視頻,最終動畫也只有3/24秒。
這時候,ip_freq插值(線性)就開始發(fā)揮作用了,如果插值是一個季度,則得出的數(shù)據(jù)就變成了這樣:
具體的插值時間間隔為多久,則要視具體的數(shù)據(jù)而定,一般繪制大數(shù)據(jù)時,設置為ip_freq = None。
至此,就能生成數(shù)據(jù)動畫了,完整代碼如下所示:
這是插值為兩天,生成的動畫效果。
最后還有一個問題,那就是保存動畫,有兩個格式可以選擇:gif或者mp4。
保存為動圖一般使用:?
若要保存為mp4的話,ffmpeg是個不錯的選擇,它是保存為mp4的標準編寫器。
或者:
當然,同樣也可以使用Canvas.save()來保存。
作者介紹
julkar9,Python/Flutter 開發(fā)人員,研究的方向為數(shù)據(jù)分析與可視化。
小哥表示,Pynimate還會不斷更新,目前正在接受大家的反饋,之后還會上線等值區(qū)域圖等功能。
他還開發(fā)了一個應用程序:Chatmetry,同樣也與數(shù)據(jù)統(tǒng)計有關,是一個用于創(chuàng)建whatsapp聊天統(tǒng)計數(shù)據(jù)的機器人應用程序。
這個程序可以從導出的聊天中生成各種統(tǒng)計信息,同時支持個人和群組聊天,并且是完全離線的,既不會保存也不會共享。
?傳送門:???https://julkaar9.github.io/pynimate/?