(二十)Seaborn知识学习7-python数据分析与机器学习实战(学习笔记)

文章原创,最近更新:2018-05-14

1.绘制数据网格
2.用FacetGrid子集数据
3.用PairGrid and pairplot()绘制成对的关系

课程来源: python数据分析与机器学习实战-唐宇迪

学习参考链接:
1、Seaborn(sns)官方文档学习笔记(第六章 绘制数据网格)
2、Seaborn官方0.8.1版本

引言:这节课我们讲Facetgrid,就是将很多子集进行展示,就可以用到这个函数.

1.绘制数据网格

在探索中等维度数据时,一个有用的方法是在数据集的不同子集上绘制相同绘图的多个实例。这种技术有时被称为“格子”或“格子”绘图,它与“小倍数”的想法有关。 它允许观看者快速提取大量关于复杂数据的信息。 Matplotlib可以很好地支持制作具有多个轴的图形; seaborn建立在此之上,以将结构直接链接到数据集结构上进行绘制。

要使用这些功能,您的数据必须位于Pandas DataFrame中,并且必须采用Hadley Whickam称为“整洁”数据的形式。 简而言之,这意味着您的数据框架应该被结构化,使得每一列都是一个变量,每一行都是一个观测。

2.用FacetGrid子集数据

当您想要在数据集的子集内可视化变量的分布或多个变量之间的关系时,FacetGrid类很有用。 FacetGrid可以绘制最多三个维度:row,col和hue。前两者与所得轴数有明显的对应关系;将hue变量视为沿着深度轴的第三维,其中不同的级别用不同的颜色绘制。

通过使用数据框初始化FacetGrid对象和将形成网格的行,列或色调维度的变量的名称来使用该类。 这些变量应该是分类的或离散的,然后变量的每个级别的数据将用于沿该轴的小平面。 例如,假设我们要检查tips数据集中的午餐和晚餐之间的差异。

另外,lmplot()和factorplot()在内部使用这个对象,并且当它们被修改时,它们返回该对象,以便可以用于进一步的调整。

这里使用的数据集是seaborn的自带的数据集"Tips",我们先看看前五项的数据集,都包含有什么内容?

案例代码如下:

import seaborn as sns

sns.set(style="ticks")
tips=sns.load_dataset("tips")
print(tips.head())

输出结果如下:

   total_bill   tip     sex smoker  day    time  size
0       16.99  1.01  Female     No  Sun  Dinner     2
1       10.34  1.66    Male     No  Sun  Dinner     3
2       21.01  3.50    Male     No  Sun  Dinner     3
3       23.68  3.31    Male     No  Sun  Dinner     2
4       24.59  3.61  Female     No  Sun  Dinner     4

在sns.FacetGrid()函数在未设置其他参数的情况下,只是导进数据集,设置绘制数据集的维度col,我们看看是长啥样的?

案例代码如下:

import seaborn as sns

sns.set(style="ticks")
tips=sns.load_dataset("tips")
g=sns.FacetGrid(tips,col="time")

输出结果如下:


从输出的结果来看是个空白的图,就好比是先把位置先占上了.一会在这个位置上进行绘图,左右两个图分别代表time的一个指标,但是还没告诉seaborn以什么样的图形方式去绘制这个图形?

像这样初始化网格设置了matplotlib图形和轴,但并没有绘制任何东西。

在此网格上可视化数据的主要方法是使用FacetGrid.map()方法,提供一个绘图功能和数据框中变量的名称来绘制。我们来看一下这些子集中提示的分布,使用直方图。

g.map(plt.hist,"tip")中的参数plt.hist表示绘制条形图.

案例代码如下:

import seaborn as sns
import matplotlib.pyplot as plt

sns.set(style="ticks")
tips=sns.load_dataset("tips")
g=sns.FacetGrid(tips,col="time")
g.map(plt.hist,"tip")

输出结果如下:



从绘制的结果我们可以看出,首先将用sns.FacetGrid()函数将图形和轴绘制出来,再用map()函数传入绘制图型的类别以及x轴的数据集.alpha这里指的是透明程度0.7(越小越透明,越大越不透明),原因是在散点图绘制点的时候可能会进行重叠.

通过用sns.FacetGrid()函数绘制tips数据集,并且以性别为维度,以及用hue指定变量,是否抽烟?

案例代码如下:

import seaborn as sns
import matplotlib.pyplot as plt

sns.set(style="ticks")
tips=sns.load_dataset("tips")
g=sns.FacetGrid(tips,col="sex",hue="smoker")
g.map(plt.scatter,"total_bill","tip",alpha=.7)

输出结果如下:


从输出结果来看,绿色的点与蓝色的点分别代表什么?看不出来,就需要增加add_legend()函数增加图例,有类别的说明.

案例代码如下:

import seaborn as sns
import matplotlib.pyplot as plt

sns.set(style="ticks")
tips=sns.load_dataset("tips")
g=sns.FacetGrid(tips,col="sex",hue="smoker")
g.map(plt.scatter,"total_bill","tip",alpha=.7)
g.add_legend()

输出结果如下:



从输出的结果可以看出,右边多了一个smoker图例.

我们可以对g.map()中的属性color对点的颜色进行更改.数值越小颜色越深,数值越大颜色越浅.x_jitter表示数据的抖动,让数据左右偏移.fit_reg=False表示回归的线不画出来,如果是True就会画出来.

案例代码如下:

import seaborn as sns
import matplotlib.pyplot as plt

sns.set(style="ticks")
tips=sns.load_dataset("tips")
g=sns.FacetGrid(tips,row="smoker",col="time",margin_titles=True)
g.map(sns.regplot,"size","total_bill",color=".3",fit_reg=False,x_jitter=.1)

输出结果如下:

此外,我们还可以通过提供每个图形的高度以及纵横比来达到设置图形大小的目的。

比如在sns.FacetGrid()函数设置绘制图形的纵横比,size设置每个图形的高度,并且用条形图绘制出来.

案例代码如下;

import seaborn as sns
import matplotlib.pyplot as plt

sns.set(style="ticks")
tips=sns.load_dataset("tips")
g=sns.FacetGrid(tips,col="day",size=4,aspect=.5)
g.map(sns.barplot,"sex","total_bill")

输出结果如下:

每个图形的高度以及纵横比根据自己实际的需要进行设置.对于图形的整体布局都是用sns.FacetGrid()函数进行设置.

这里,默认的顺序来自于DataFrame中的书序。如果用于定义facets具有分类变量的类型,则会实用类别的顺序。否则,facets将按照级别的顺序排列。当然,也可以使用适当的*_order参数来指定任何平面维度的数据顺序。

这里我们可以设置先后的顺序.

我们先看ordered_days = tips.day.value_counts().index,打印的结果如下:

CategoricalIndex(['Sat', 'Sun', 'Thur', 'Fri'], categories=['Thur', 'Fri', 'Sat', 'Sun'], ordered=False, dtype='category')

画图的时候希望可以自己指定顺序,按照ordered_days 的输出结果,第一个画的是'Sat', 第二个画的是'Sun', 第三个画的是'Thur',第四个画的是 'Fri',这样可以么?

这个是可以的,可以用sns.FacetGrid()函数中的row_order参数等于指定好的顺序,比如设置row_order=ordered_days.

此外,sns.FacetGrid()函数有个要求,传进来的数据要求都是DataFrame的格式.传参数的时候,最好都是DataFrame的格式,是sns.FacetGrid()函数默认支持的一个格式,用其他数据类型的格式就不保证是否会出现错误.

案例代码如下:

import seaborn as sns

sns.set(style="ticks")
tips=sns.load_dataset("tips")
ordered_days = tips.day.value_counts().index
g = sns.FacetGrid(tips, row="day", row_order=ordered_days,
                  size=1.7, aspect=4,)
g.map(sns.boxplot, "total_bill")

输出结果如下:


如果想把指定的顺序'Sat', 'Sun', 'Thur', 'Fri'更改为'Thur', 'Fri','Sat', 'Sun',就需要用到pandas 的 Categorical.

案例代码如下:

import seaborn as sns
from pandas import Categorical

sns.set(style="ticks")
tips=sns.load_dataset("tips")
ordered_days = tips.day.value_counts().index
ordered_days=Categorical(['Thur', 'Fri','Sat', 'Sun'])
g = sns.FacetGrid(tips, row="day", row_order=ordered_days,
                  size=1.7, aspect=4,)
g.map(sns.boxplot, "total_bill")

输出结果如下:



输出的结果是按照'Thur', 'Fri','Sat', 'Sun'这样的顺序进行输出的.

如何对设置绘图的颜色呢?

可以提供任何Seaborn调色板(即可以传递给color_palette()的参数),还可以使用将色调变量中值的名称映射到有效的matplotlib颜色的字典:

FacetGrid()函数中的palette,指定点的颜色.

map()函数中的s=50,表示绘制图形中点的大小.alpha=.7表示透明的程度,linewidth=.5表示线宽,edgecolor="white"表示每个点的边界颜色.
案例代码如下:

import seaborn as sns
import matplotlib.pyplot as plt

sns.set(style="ticks")
tips=sns.load_dataset("tips")
pal=dict(Lunch="seagreen",Dinner="gray")
g = sns.FacetGrid(tips, hue="time", palette=pal,
                  size=5)
g.map(plt.scatter, "total_bill","tip",s=50,alpha=.7,linewidth=.5,edgecolor="white")
g.add_legend()

输出结果如下:


是否可以指定散点图中点的形状呢?
在 sns.FacetGrid()函数中,设置hue_kws={"marker": ["^", "v"]},可以实际画出当前的一个形状.

案例代码如下:

import seaborn as sns
import matplotlib.pyplot as plt

sns.set(style="ticks")
tips=sns.load_dataset("tips")
g = sns.FacetGrid(tips, hue="sex", palette="Set1",
                  size=5,hue_kws={"marker": ["^", "v"]})
g.map(plt.scatter, "total_bill","tip",s=100,linewidth=0.5,edgecolor="white")
g.add_legend()

输出结果如下:


如何更改绘制图形的轴呢?

FacetGrid对象上还有一些方法可以在更高层次的抽象上操作图形。 最通用的是FacetGrid.set(),还有其他更专门的方法,如FacetGrid.set_axis_labels(),它遵循内部方面没有轴标签的效果。 例如:

案例代码如下:

import seaborn as sns
import matplotlib.pyplot as plt

tips=sns.load_dataset("tips")
with sns.axes_style("white"):
    g = sns.FacetGrid(tips,row="sex",col="smoker", margin_titles=True,
                  size=2.5)


g.map(plt.scatter, "total_bill","tip",color="#334488",edgecolor="white",lw=.5)
g.set_axis_labels("Total bill (US Dollars)", "Tip")
g.set(xticks=[10, 30, 50], yticks=[2, 6, 10])
g.fig.subplots_adjust(wspace=.02, hspace=.02)  

输出结果如下:


案例分析:

  • with sns.axes_style("white")这个是设置绘制图形的风格.
  • g = sns.FacetGrid(tips,row="sex",col="smoker",
    margin_titles=True,size=2.5)是指怎么绘制图型的.
  • g.set_axis_labels("Total bill (US Dollars)", "Tip")分别设置x,y轴的名字.
  • g.set(xticks=[10, 30, 50], yticks=[2, 6, 10])分别是x,y轴的取值范围.
  • g.fig.subplots_adjust(wspace=.02, hspace=.02) 设置子图的的横向和纵向的间隔.

3.用PairGrid and pairplot()绘制成对的关系

该类的基本用法与FacetGrid非常相似。首先初始化网格,然后将绘图函数传递给map方法,并在每个子图上调用它。还有一个配套功能,pairplot()交易了一些灵活性更快的绘图。

案例代码如下:

import seaborn as sns
import matplotlib.pyplot as plt

iris=sns.load_dataset("iris")
g=sns.PairGrid(iris)
g.map(plt.scatter)

输出结果如下:


在画PairGrid()图时,可以设置对角线画什么类型的图比如g.map_diag(plt.hist)设置对角线画直方图.以及非对角线又是画什么样类型的图,比如g.map_offdiag(plt.scatter),设置非对角线是散点图.

可以在对角线上绘制不同的函数,以显示每列中变量的单变量分布。 请注意,轴刻度线将不对应于该图的计数或密度轴。

案例代码如下;

import seaborn as sns
import matplotlib.pyplot as plt

iris=sns.load_dataset("iris")
g=sns.PairGrid(iris)
g.map_diag(plt.hist)
g.map_offdiag(plt.scatter)

输出结果如下:


也可以在sns.PairGrid()函数中增加区分的类别,比如hue="species",这里增加物种是个类别,并且用不同的颜色来表示.

使用该图的非常常见的方法是通过单独的分类变量来绘制观察值。 例如,虹膜数据集对于三种不同种类的鸢尾花中的每一种进行四次测量,以便您可以看到它们如何不同。

案例代码如下:

import seaborn as sns
import matplotlib.pyplot as plt

iris=sns.load_dataset("iris")
g=sns.PairGrid(iris,hue="species")
g.map_diag(plt.hist)
g.map_offdiag(plt.scatter)
g.add_legend()

输出结果如下:


之前的图像都是两两特征进行对比,如果只是想取其中的两个特征对比,又应该怎么操作呢?

默认情况下,使用数据集中的每个数字列,但如果需要,您可以专注于特定的关系。比如可以用sns.PairGrid()中的vars属性,设置指定的的特征名字即可.

案例代码如下:

import seaborn as sns
import matplotlib.pyplot as plt

iris=sns.load_dataset("iris")
g=sns.PairGrid(iris,vars=["sepal_length", "sepal_width"], hue="species")
g.map(plt.scatter)

输出结果如下:


怎么设置sns.PairGrid()函数的调色板?

sns属性是可配置的。 例如,您可以使用不同的调色板(例如,显示色调变量的顺序),并将关键字参数传递到绘图函数中。

比如设置sns.PairGrid()函数中的palette="GnBu_d",可以设置好调配板的颜色.

案例代码如下:

import seaborn as sns
import matplotlib.pyplot as plt

tips=sns.load_dataset("tips")
g=sns.PairGrid(tips, hue="size",palette="GnBu_d")
g.map(plt.scatter,s=50,edgecolor="white")
g.add_legend()

输出结果如下:


©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容