算技@数据可视化

2016-11-06  本文已影响101人  苏尚君

起因

之前就觉得能够将数据可视化的话将非常有助于读者理解数据的意义,减少沟通成本(即“进行数据分析时”的数据分析者与“其他时刻的人”之间的沟通,包括“一个月以后的自己”)

在 MLND 的课程中,做到 P ... 时,有个 reviewer 的意见启发了我:ta 说,可以把可视化后的数据呈现作为证据。因此在 P3 需要“从数据集中选择三个你希望抽样的数据点的索引”,“找到三个明显不同的客户”时,我就想到:

能不能把我感兴趣的数据点的数据分布趋势作图表示,从而直观地比较了解它们的构成差异,更容易找到明显不同的三个数据点/在呈现报告是更有说服力?

说干就干。在作图前,大约需要了解 3 个方面:

  1. 【哪些工具】在进行数据分析时,常见的图形有哪些?
    • 例如:频率分布直方图、饼图、……
  2. 【工具特点】上述这些图形分别适用于反映/比较数据的哪些特征?
  3. 【问题特点】我的问题是什么
    • 其实这里已经明确了:由于每个数据点都由多个维度的值组合而成,我需要(通过一种图形来反映出)各个数据点之间的数据构成/分布差异

哪些工具 & 工具特点

很容易想到:Excel 中提供了常用的一些数据绘图工具。因此不妨将 Excel 已有的图形工具以及相应提示作为一个入门索引。

根据 MS Excel 2016 的提示,至少有以下几种图形工具可以考虑:

问题特点

。。。

绘制方法

饼图

采用 matplotlib.pylot.pie,用法:

matplotlib.pyplot.pie(*x*, *explode=None*, *labels=None*, *colors=None*, *autopct=None*, *pctdistance=0.6*, *shadow=False*, *labeldistance=1.1*, *startangle=None*, *radius=None*, *counterclock=True*, *wedgeprops=None*, *textprops=None*, *center=(0*, *0)*, *frame=False*, *hold=None*, *data=None*)

结合官方文档和例子(123)理解参数意义:

踩坑

  1. 当绘制多个饼图时,若未考虑到半径大小(默认为 1)与饼图中心的关系,将出现重叠
  2. 当未指定饼图坐标轴时,默认绘制出的饼图是椭圆状的。指定了 plt.axis('equal') 后才能绘制出圆饼图

并列多张饼图

需要用到 matplotlib.pyplot.subplots(nrows=1, ncols=1, sharex=False, sharey=False, squeeze=True, subplot_kw=None, gridspec_kw=None, **fig_kw)

例如要并列 2 张饼图,请参考示例代码:

f, (ax1, ax2) = plt.subplots(1, 2, sharey='col')
ax1.pie(write your args for pie1)
ax1.set_title('pie 1')
ax2.pie(write your args for pie2)
ax2.set_title('pie 2')

是的,第一句代码生成的 2 个 matplotlib.axes.Axes 对象可以直接使用 .pie(args) 方法。更多有关 matplotlib.axes.Axes 对象的方法,请参考这里

条形图/柱状图

matplotlib.pyplot.bar(left, height, width=0.8, bottom=None, hold=None, data=None, **kwargs) 默认绘制垂直状的柱状图:

参数意义:

。。。

踩坑

  1. 条形图不是直方图!
  1. 当标签数量多、且标签名普遍较长时,建议改成水平放置的柱状图,即使用 matplotlib.pyplot.barh,如下对比:
标签密集的垂直条形图 同一数据集的水平条形图

绘制水平条形图(水平柱状图)

matplotlib.pyplot.barh(bottom, width, height=0.8, left=None, hold=None, **kwargs)

参数意义:

。。。

上一篇 下一篇

猜你喜欢

热点阅读