成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

丟掉Excel,手把手教你用Python做可視化數(shù)據(jù),還能任意調(diào)節(jié)動畫絲滑度

開發(fā) 新聞
一個簡單的Python包就能分分鐘搞定!

本文經(jīng)AI新媒體量子位(公眾號ID:QbitAI)授權(quán)轉(zhuǎn)載,轉(zhuǎn)載請聯(lián)系出處。

數(shù)據(jù)可視化動畫還在用Excel做?

現(xiàn)在一個簡單的Python包就能分分鐘搞定!

而且生成的動畫也足夠絲滑,效果是醬紫的:

圖片

這是一位專攻Python語言的程序員開發(fā)的安裝包,名叫Pynimate。

目前可以直接通過PyPI安裝使用。

圖片

使用指南

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

import pynimate as nim

而創(chuàng)建這種動畫,輸入的數(shù)據(jù)必須是pandas數(shù)據(jù)結(jié)構(gòu)(如下),其中將時間列設(shè)置為索引,換句話說索引代表的是自變量。

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ù),寫成代碼應(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ù)動畫,Barplot還有三個必需的參數(shù)得注意:data、time_format和ip_freq(Interpolation frequency)。

data就是表格的數(shù)據(jù),這里也就不再贅述。

time_format是指數(shù)據(jù)索引的時間日期格式,一般為:”%Y-%m-%d”。

最后是ip_freq,它是制作動畫中比較關(guān)鍵的一步,通過線性插值使動畫更加流暢絲滑。

一般來說,并不是所有的原始數(shù)據(jù)都適合做成動畫,現(xiàn)在一個典型的視頻是24fps,即每秒有24幀。

舉個栗子??,下面這個表格中的數(shù)據(jù)只有三個時間點,按理說只能生成3幀視頻,最終動畫也只有3/24秒。

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

這時候,ip_freq插值(線性)就開始發(fā)揮作用了,如果插值是一個季度,則得出的數(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ù)據(jù)而定,一般繪制大數(shù)據(jù)時,設(shè)置為ip_freq = None。

至此,就能生成數(shù)據(jù)動畫了,完整代碼如下所示:

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的標(biāo)準(zhǔn)編寫器。

 pip install ffmpeg-python

或者:

conda install ffmpeg

當(dāng)然,同樣也可以使用Canvas.save()來保存。

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

作者介紹

julkar9,Python/Flutter 開發(fā)人員,研究的方向為數(shù)據(jù)分析與可視化。

小哥表示,Pynimate還會不斷更新,目前正在接受大家的反饋,之后還會上線等值區(qū)域圖等功能。

圖片

他還開發(fā)了一個應(yīng)用程序:Chatmetry,同樣也與數(shù)據(jù)統(tǒng)計有關(guān),是一個用于創(chuàng)建whatsapp聊天統(tǒng)計數(shù)據(jù)的機器人應(yīng)用程序。

這個程序可以從導(dǎo)出的聊天中生成各種統(tǒng)計信息,同時支持個人和群組聊天,并且是完全離線的,既不會保存也不會共享。

圖片

?傳送門:???https://julkaar9.github.io/pynimate/?

責(zé)任編輯:張燕妮 來源: 量子位
相關(guān)推薦

2020-12-17 09:40:01

Matplotlib數(shù)據(jù)可視化命令

2011-03-28 16:14:38

jQuery

2021-08-09 13:31:25

PythonExcel代碼

2021-07-14 09:00:36

Python數(shù)據(jù)Python基礎(chǔ)

2021-08-26 09:00:48

PyechartsPython可視化

2022-07-24 21:43:48

數(shù)據(jù)可視化大數(shù)據(jù)

2021-05-10 06:48:11

Python騰訊招聘

2021-03-23 09:05:52

PythonExcelVlookup

2022-10-19 14:30:59

2020-03-08 22:06:16

Python數(shù)據(jù)IP

2021-02-02 13:31:35

Pycharm系統(tǒng)技巧Python

2021-12-11 20:20:19

Python算法線性

2022-08-04 10:39:23

Jenkins集成CD

2021-02-04 09:00:57

SQLDjango原生

2021-02-06 14:55:05

大數(shù)據(jù)pandas數(shù)據(jù)分析

2009-04-22 09:17:19

LINQSQL基礎(chǔ)

2021-05-17 21:30:06

Python求均值中值

2025-06-13 08:26:08

JetpackCompose按鈕

2012-01-11 13:40:35

移動應(yīng)用云服務(wù)

2021-08-02 23:15:20

Pandas數(shù)據(jù)采集
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 精品欧美一区二区精品久久久 | 免费看日韩视频 | 99精品久久 | 91精品免费视频 | 日日操视频 | 6080yy精品一区二区三区 | 男女视频免费 | 一区中文字幕 | 久久精品a级毛片 | 日日夜夜精品免费视频 | 国产欧美精品区一区二区三区 | 午夜精品久久久久久久久久久久久 | 玖玖色在线视频 | 中国大陆高清aⅴ毛片 | 一级在线毛片 | 69热视频在线观看 | 五月精品视频 | 欧美激情久久久 | 日韩欧美在 | 欧美日韩专区 | av黄色片在线观看 | 国产黄色麻豆视频 | 美女爽到呻吟久久久久 | 国产高清精品在线 | 午夜99| 国产高清在线观看 | 国产成人精品午夜视频免费 | 91久久国产综合久久91精品网站 | 国产精品自产av一区二区三区 | 成人精品网 | 久久久久久中文字幕 | 伊人青青久久 | 艹逼网 | 韩国精品在线观看 | 久久精品免费观看 | 国产精品一区二区av | 国产精品夜夜夜一区二区三区尤 | 91超碰在线 | 中文字幕亚洲区一区二 | 国产精品久久久久久久岛一牛影视 | 国产日产欧产精品精品推荐蛮挑 |