python绘图包效率_比 matplotlib 效率高十倍的数据可视化神器
来源:优达学城Udacity
https://towardsdatascience.com/the-next-level-of-data-visualization-in-python-dd6e99039d5e
心理学上有一个名词叫“沉没成本谬误”,它指如果我们已经在一项事业上花费了很多时间,那么即使明知是失败的,我们仍然会倾向于继续把时间和资源花在上面。
在数据可视化的路上,我也曾犯过这样的错误。
当我明知存在更高效、更具交互性和外观更好的替代方案时,我却仍然继续使用一个过时的绘图库——matplotlib,只是因为我曾经花了数百个小时来学习 matplotlib 复杂的语法。
幸运的是,现在有许多的开源绘图库可供选择,经过仔细研究,我发现 plotly 包无论从易用性、交互性还是功能性来看,都有绝对的优势。接下来,我将带领大家学会如何用更少的时间绘制更美观的可视化图表——通常只需要一行代码。
本文所有代码都可以在 GitHub 上找到。读者朋友们也可以直接在浏览器里打开 NBViewer 链接查看效果。地址获取方式见文末。
文章图片
Plotly简要概述
plotly Python 包是一个构建在 plotly.js 上的开源库,而后者又是构建在 d3.js 上的。我们将使用一个 plotly 的“包装器”——cufflinks,它可以 plotly 的使用变得更加简单。整个堆叠顺序是cufflinks>plotly>plotly.js>d3.js,意味着我们同时获得了 Python 的编程高效性和d3强大的图形交互能力。(毕竟d3.js是全世界公认的第一可视化框架!)
本文中所有工作都是使用 plotly+cufflinks 在 Jupyter Notebook 中完成的。在开始前,我们需要使用pip install cufflinks plotly在 Python 环境中安装这两个包,然后在 jupyter notebook 中导入这两个包:
# 导入plotly包import plotly.plotly as pyimport plotly.graph_objs as gofrom plotly.offline import iplot,init_notebook_mode# 使用离线模式的 plotly + cufflinksimport cufflinkscufflinks.go_offline(connected=True)
单变量分布:直方图和箱线图
单变量-单变量制图是开始一个数据分析的标准方法。直方图是绘制单变量分布的首选方式。在这里,我使用的数据来源是我个人在 medium 网站上所写过文章的统计信息,让我们先来制作一个关于文章点赞次数的交互式直方图(df 是一个标准的 Pandas 数据结构)。
df['claps'].iplot(kind='hist', xTitle='claps', yTitle='count', title='Claps Distribution')
文章图片
如果你已经习惯使用matplotlib,你所需要做的只是在你原有代码的基础上添加一个字母,即把 plot 改为 iplot,就可以得到一个更加好看的交互式图标!我们可以通过鼠标的滑动获得更多的数据几节,还可以放大图的各个部分。
如果我们想要绘制重叠的直方图,这很简单:
df[['time_started', 'time_published']].iplot(kind='hist',histnorm='percent',barmode='overlay',xTitle='Time of Day',yTitle='(%) of Articles',title='Time Started and Time Published')
文章图片
通过一点pandas处理,我们还可以制作一个条形图:
#重采样获得每月的均值 e Views and Reads')df2 = df[['view','reads','published_date']].set_index('published_date').resample('M').mean()df2.iplot(kind='bar', xTitle='Date', yTitle='Average', title='Monthly Average Views and Reads')
文章图片
就像我们前面看到的那样,pandas+plotly+cufflinks 这一组合的功能非常强大。如果我们要绘制一个关于每篇文章粉丝数量在不同发表渠道的分布情况的箱线图,我们可以先使用 pandas 中DataFrame 的 pivot(透视表) 功能,然后再绘制图表,如下:
df.pivot(columns='publication', values='fans').iplot( kind='box', yTitle='fans',title='Fans Distribution by Publication')
文章图片
交互式图表的好处就在于,我们可以尽情地探索图表中的数据。特别是在箱线图中,包含的信息很多,如果不能局部放大查看,我们可能会错过这些信息。
散点图
散点图是大多数分析的核心,它可以使我们看到变量随着时间的演变情况,也可以看到两种变量之间的关系。
时间序列
现实世界中的大部分数据都与时间相关。幸运的是,plotly + cufflinks 在设计之初就考虑到了时间序列的可视化。让我们来创建一个关于我写过文章情况的 dataframe,看看它的各项指标是怎么随着时间变化的。
#创建一个数据集,只包括发布在Towards Data Science渠道的文章tds = df[df['publication'] == 'Towards Data Science']. set_index('published_date')#将阅读时间作为时间序列tds[['claps', 'fans', 'title']].iplot( y='claps', mode='lines+markers', secondary_y = 'fans', secondary_y_title='Fans', xTitle='Date', yTitle='Claps', text='title', title='Fans and Claps over Time')
文章图片
我们在一行代码里完成了很多不同的事情:
- 自动获得了格式友好的时间序列作为x轴
- 添加一个次坐标轴(第二y轴),因为上图中的两个变量的值范围不同。
- 添加文章的标题到每个数据点中(鼠标放上去可以显示文章名和变量值)
如果要从图表上了解更多的信息,我们还可以很容易地添加文本注释:
tds_monthly_totals.iplot(mode='lines+markers+text', text=text, y='word_count', opacity=0.8, xTitle='Date', yTitle='Word Count',title='Total Word Count by Month')
文章图片
对于由第三个分类变量着色的双变量散点图,我们使用:
#read_time代表文章所需阅读时长,read_ratio代表阅读比例,即阅读文章的人数/点击查看的人数df.iplot( x='read_time', y='read_ratio',# 定义类别变量categories='publication',xTitle='Read Time',yTitle='Reading Percent', title='Reading Percent vs Read Ratio by Publication')
文章图片
如果要在图表中体现三个数值变量,我们还可以使用气泡图,如下图:横坐标、纵坐标、气泡的大小分别代表三个不同的变量——文章字数的对数、阅读数量、阅读比例。
tds.iplot(x='word_count',y='reads', size='read_ratio',text=text, mode='markers',# Log xaxislayout=dict(xaxis=dict(type='log', title='Word Count'), yaxis=dict(title='Reads'), title='Reads vs Log Word Count Sized by Read Ratio'))
文章图片
再做一点工作,我们甚至可以在一个图表中体现四个变量!
文章图片
结合 pandas 对数据进行统计处理,我们可以得到很多非常有价值的图,比如下面这张关于不同文章发表渠道的读者点击查看数量的变化趋势图,显然名为Toward Data Science的发表渠道能给文章带来更多的点击量。
文章图片
更高级的图表
接下来所讲述的图表大家可能不会经常用到,但是非常酷炫,值得了解一下。同样,我们仍然只使用一行代码就可以完成这些超级图表。
散点图矩阵
当我们想要探索许多变量之间的关系时,散点图矩阵是非常好的选择。
import plotly.figure_factory as fffigure = ff.create_scatterplotmatrix(df[['claps', 'publication','views','read_ratio','word_count']],diag='histogram', index='publication')
文章图片
以上的散点矩阵图仍然是可以交互的,可以自由放大缩小,查看各个数据点的详细信息。
相关系数热力图
为了将数值型变量的相关性可视化,我们可以先计算相关系数,接着就可以创建一个带注释的热力图:
corrs = df.corr()figure = ff.create_annotated_heatmap(z=corrs.values,x=list(corrs.columns),y=list(corrs.index), annotation_text=corrs.round(2).values, showscale=True)
文章图片
文章图片
我们还可以绘制非常酷炫的3D表面图和3D气泡图:
文章图片
文章图片
云制图——Plotly Chart Studio
当你使用 plotly 在 notebook 中绘制图表时,你可能注意到了每幅图的右下角都有一个链接 “Export to plot.ly” 。如果你点击该链接,就会跳转到名为chart studio的云制图平台,然后你就可以对自己的图标进行润色,添加注释、改改颜色、清理一些不必要的内容等等。
文章图片
你还可以在线发布该图表,任何人可以直接通过链接访问到你的图表。(比如我的这个3D图,在浏览器中输入后方链接可直接抵达:https://plot.ly/~Allencxl/3/)
前面所述的内容还不算是这个库的所有功能,非常鼓励各位小伙伴们去查看 plotly 和 cufflinks 的文档,肯定会有更多不可思议的神级可视化在等着你!
文章图片
美国风力发电厂的分布情况
总结
我已经因为固执地使用matploblib而浪费了太多时间,所以希望大家能通过这篇文章学习到一种新的方式提升自己的绘图效率。另外,当我们在选择绘图库的时候,有几点是永远需要考虑的:
- 用少量的代码进行数据探索
- 可以实时与数据交互,查看数据子集情况
- 根据自己的需要,选择性挖掘数据中的细节
- 非常便利地润色最终演示的图表
而到目前为止,能够在 Python 中实现上述需求的不二选择便是 plotly。plotly 使我们能够快速地进行可视化,让我们通过与图表的交互更好地了解我们的数据。日常工作中,在使用其他绘图库的时候,我感觉绘图是一项单调乏味的任务,但是使用 plotly 时,我觉得绘图是数据科学中相当有趣的工作之一!
公众号后台回复plotly可视化获取本文图表、网页浏览地址、源代码地址、数据地址。
文章图片
文章图片
【python绘图包效率_比 matplotlib 效率高十倍的数据可视化神器】分享或在看是对我最大的支持
推荐阅读
- opencv4|opencv4 python环境_opencv+python+pyqt+eric4开发环境搭建 | 学步园
- python|Python基于协同过滤算法的电影推荐系统设计与实现
- python|数据分析--pandas常用操作
- Python|Python 获取字典中的第一个键
- Python|我写的 Python 代码,同事都说好
- pygame|Python学习路线图(2022年最新版)
- Python|错误的路线害死人,2022最全Python爬虫学习路线和学习资料
- 大作业|Python大作业一
- python|学了这么久python,你居然还不知道什么是爬虫(看完这篇文章你就明白了!)
- Python 自动清理电脑垃圾文件,一键启动即可