两个简单的代码片段让你的图表动起来
点击上方“Deephub Imba”,关注公众号,好文章不错过 !
我们以前也发过很多关于数据可视化的文章。但是对于展示来说,如果你的图表能够动起来,那么他的展示效果要比静态的图有更多的冲击力,尤其是你需要向领导和客户展示的时候。所以在本篇文章整列了2个简单的代码片段,可以让你的图表动起来。
动画
Python中有许多用于绘制图形的库。Matplotlib, Seaborn, Bokeh, Plotly等等。
但是我们绘图的目的是要向听众和要传递的信息。如果你的图能够动起来那么他们肯定会让听众在看第一眼的时候就印象深刻。但是并不是每个图形或数据集都适合动画。一般情况下,动画对时间序列来说非常有效。例如,根据时间变化进行数据的对比。
Plotly Express
Plotly Express,可以直接为我们创建动态图表:
import plotly.express as px
import pandas as pd
import numpy as np
让我们在数据集中创建一些值。
df = pd.DataFrame( {'week': np.random.randint(1,21, size=200),
'P1': np.random.randint(10,220, size=200),
'P2': np.random.randint(15,200, size=200),
'P3': np.random.randint(10,490, size=200),
'P4': np.random.randint(10,980, size=200) } )
df = pd.DataFrame( {'week': np.random.randint(1,21, size=200),
'P1': np.random.randint(10,220, size=200),
'P2': np.random.randint(15,200, size=200),
'P3': np.random.randint(10,490, size=200),
'P4': np.random.randint(10,980, size=200) } )
现在我们可以绘制一个动画图来查看产品按周的变化情况。
创建散点图动画也同样简单。
fig = px.scatter(df, x="week", y="sales", animation_frame="week", animation_group="product", size="sales", color="product", hover_name="product", range_x=[0,20], range_y=[0,800])
fig.update_layout(height=600, width=1000)
gif库
如果你像我一样是matplot和seaborn的粉丝,并且不太喜欢用Plotly的话,那么可以试试这个库。这个库的作用是创建一系列绘图,并将它们放在一个帧序列中并创建一个动态的gif图。
首先,还是获取一些用于绘图的时间序列数据。
import seaborn as sns
df = sns.load_dataset('flights')
接下来创建一个函数,该函数将为每个观察创建一个绘图。
@gif.frame
def plot_flights(df, i):
df = df.copy()
# Get the year for the plot title
yr = df['year'][i]
# Force X axis to be entirely plotted at once
df.iloc[i:] = np.nan
#Plot
ax = df.plot(x='month', y= 'passengers', legend=False,
style="o-", figsize=(20,10))
ax.set_title(f"Air Passengers {yr}", size=20)
ax.set_xlabel("Months")
ax.set_ylabel("Number of Passengers")
@gif.frame
是GIF库用来创建帧序列的装饰器。
df.iloc[i:] = np.nan
将把所有未来的数据转换到NA。这是一种每次只绘制一个值的编程方式(i=0所有都为nan, i=1,只绘制索引0,i=2,只绘制0和1…),通过这种方法我们可以端到端绘制X轴,因为在动画期间是不会改变的。这样也可以保持图表的大小不变,使其更容易观看。
现在我们使用函数创建一个循环来创建帧。
frames = []
for i in range(df.shape[0]):
frame = plot_flights(df, i)
frames.append(frame)
最后,保存生成的GIF图像。
gif.save(frames, 'gif_example.gif', duration=180)
看,是不是很简单
最后总结
动画图是一个很有影响力的展示方法,但是并不是所有的图都适合动画化。我们应该根据实际的情况来选择是否需要创建动画图,因为动画图并不是深入分析的最佳选择他只是在视觉上有一些更大的冲击,所以当你需要观察、比较和理解时也许静态图是更好的选择。
要创建动图,我建议您使用gif库,因为对于这种图形类型,它比plotly更简单(因为我个人更喜欢seaborn,哈)。如果你对gif库感兴趣,可以去看看他们的官网:
https://github.com/maxhumber/gif
当然也别忘了plotly:
https://plotly.com/python/animations/
作者:Gustavo Santos
MORE
kaggle比赛交流和组队
加我的微信,邀你进群
喜欢就关注一下吧:
点个 在看 你最好看!
相关文章
- Java实现水仙花数简单代码
- 【嵌入式开发】ARM 关闭中断 ( CPRS 中断控制位 | 中断使能寄存器 | 中断屏蔽寄存器 | 关闭中断 | 汇编代码编写 )
- 代码解析:随机展示 bing 每日一图
- 无需写代码能力,手搓最简单BabyGPT模型:前特斯拉AI总监新作
- php操作共享内存shmop类及简单使用测试(代码)详解编程语言
- 60 行 Python 代码爬取知乎神回复
- 一次高效简单地组织代码—简单的 ViewModel 实践
- 使用代码快速实现Redis连接简单灵活高效(用代码设置redis连接)
- 教你从零开始在 TensorFlow 上搭建 RNN(完整代码)!
- php实现的简单压缩英文字符串的代码
- fileupload控件文件类型客户端验证实现代码
- php生成xml简单实例代码
- javascript简单抽屉效果的实现代码
- php简单的会话类代码
- jquer之ajaxQueue简单实现代码
- javascript简单拖拽实现代码(鼠标事件mousedownmousemovemouseup)
- 正则表达式判断所填入号码的运营商js代码修改版
- GridView分页代码简单万能实用
- perl用grepmap求交集、并集、补集的实例代码
- 递归法求最大公约数和最小公倍数的实现代码
- JSMap和List的简单实现代码
- Asp.net图片上传实现预览效果的简单代码
- ASP.NET动态生成静态页面的实例代码
- PHP和JavaScrip分别获取关联数组的键值示例代码
- Ruby最简单的消息服务器代码
- python获取豆瓣电影简介代码分享
- js判断js函数、变量是否存在的简单示例代码
- 2014最热门的JavaScript代码高亮插件推荐
- 30个php操作redis常用方法代码例子
- Javascript拖拽的一些简单的应用(逐行分析代码,让你轻松了拖拽的原理)