文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Python中seaborn如何绘制矩阵图

2023-06-29 07:34

关注

这篇文章主要介绍了Python中seaborn如何绘制矩阵图,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

本文内容速览

Python中seaborn如何绘制矩阵图

Python中seaborn如何绘制矩阵图

1、绘图数据准备

还是使用鸢尾花iris数据集

#导入本帖要用到的库,声明如下:import matplotlib.pyplot as pltimport numpy as npimport pandas as pdfrom pandas import Series,DataFramefrom sklearn import datasetsimport seaborn as sns #导入鸢尾花iris数据集(方法一)#该方法更有助于理解数据集iris=datasets.load_iris()x, y =iris.data,iris.targety_1 = np.array(['setosa' if i==0 else 'versicolor' if i==1 else 'virginica' for i in y])pd_iris = pd.DataFrame(np.hstack((x, y_1.reshape(150,1))),columns=['sepal length(cm)','sepal width(cm)','petal length(cm)','petal width(cm)','class']) #astype修改pd_iris中数据类型object为float64pd_iris['sepal length(cm)']=pd_iris['sepal length(cm)'].astype('float64')pd_iris['sepal width(cm)']=pd_iris['sepal width(cm)'].astype('float64')pd_iris['petal length(cm)']=pd_iris['petal length(cm)'].astype('float64')pd_iris['petal width(cm)']=pd_iris['petal width(cm)'].astype('float64')  #导入鸢尾花iris数据集(方法二)#import seaborn as sns#iris_sns = sns.load_dataset("iris")

数据集简单统计

Python中seaborn如何绘制矩阵图

2、seaborn.pairplot

语法:seaborn.pairplot(data, hue=None, hue_order=None, palette=None, vars=None, x_vars=None, y_vars=None, kind='scatter', diag_kind='auto', markers=None, height=2.5, aspect=1, corner=False, dropna=True, plot_kws=None, diag_kws=None, grid_kws=None, size=None)

g = sns.pairplot(pd_iris)g.fig.set_size_inches(12,12)#figure大小sns.set(style='whitegrid',font_scale=1.5)#文本大小

Python中seaborn如何绘制矩阵图

对角线4张图是变量自身的分布直方图;

非对角线的 12 张就是某个变量和另一个变量的关系。

加上分类变量

g = sns.pairplot(pd_iris,                 hue='class'#按照三种花分类                )sns.set(style='whitegrid')g.fig.set_size_inches(12,12)sns.set(style='whitegrid',font_scale=1.5)

Python中seaborn如何绘制矩阵图

修改调色盘

可以使用Matplotlib、seaborn、颜色号list等色盘。

可参考:Python可视化学习之seaborn调色盘

import palettable g = sns.pairplot(pd_iris,                 hue='class',                 palette=palettable.cartocolors.qualitative.Bold_9.mpl_colors,#palettable颜色盘                                )sns.set(style='whitegrid')g.fig.set_size_inches(12,12)sns.set(style='whitegrid',font_scale=1.5)

Python中seaborn如何绘制矩阵图

g = sns.pairplot(pd_iris,                 hue='class',                palette='Set1',#Matplotlib颜色                                )sns.set(style='whitegrid')g.fig.set_size_inches(12,12)sns.set(style='whitegrid',font_scale=1.5)

Python中seaborn如何绘制矩阵图

g = sns.pairplot(pd_iris,                 hue='class',                palette=['#dc2624', '#2b4750', '#45a0a2'],#使用传入的颜色list                                )sns.set(style='whitegrid')g.fig.set_size_inches(12,12)sns.set(style='whitegrid',font_scale=1.5)

Python中seaborn如何绘制矩阵图

x,y轴方向选取相同子集 

import palettableg = sns.pairplot(pd_iris,                 hue='class',                 palette=palettable.cartocolors.qualitative.Bold_9.mpl_colors,                 vars=['sepal length(cm)','sepal width(cm)'],#x,y轴方向选取相同子集绘图                                )sns.set(style='whitegrid')g.fig.set_size_inches(12,6)sns.set(style='whitegrid',font_scale=1.5)

Python中seaborn如何绘制矩阵图

x,y轴方向选取不同子集

import palettableg = sns.pairplot(pd_iris,                 hue='class',                 palette=palettable.cartocolors.qualitative.Bold_9.mpl_colors,                 x_vars=['sepal length(cm)','sepal width(cm)'],#x,y轴方向选取不同子集                 y_vars=['petal length(cm)','petal width(cm)'],                                )sns.set(style='whitegrid')g.fig.set_size_inches(12,6)sns.set(style='whitegrid',font_scale=1.5)

Python中seaborn如何绘制矩阵图

非对角线散点图加趋势线 

import palettableg = sns.pairplot(pd_iris,                 hue='class',                 palette=palettable.cartocolors.qualitative.Bold_9.mpl_colors,                 kind='reg',#默认为scatter,reg加上趋势线                                                 )sns.set(style='whitegrid')g.fig.set_size_inches(12,12)sns.set(style='whitegrid',font_scale=1.5)

Python中seaborn如何绘制矩阵图

对角线上的四个图绘制方式

可选参数为‘auto’, ‘hist’(默认), ‘kde’, None。

import palettableg = sns.pairplot(pd_iris,                 hue='class',                 palette=palettable.cartocolors.qualitative.Bold_9.mpl_colors,                 diag_kind='hist',#hist直方图                                               )sns.set(style='whitegrid')g.fig.set_size_inches(12,12)sns.set(style='whitegrid',font_scale=1.5)

Python中seaborn如何绘制矩阵图

只显示网格下三角图形 

import palettableg = sns.pairplot(pd_iris,                 hue='class',                 palette='Set1',                 corner=True#图形显示左下角                                ) g.fig.set_size_inches(12,12)sns.set(font_scale=1.5)

Python中seaborn如何绘制矩阵图

图形外观设置 

import palettableg = sns.pairplot(pd_iris,                 hue='class',                 palette='Set1',                 markers=['$\clubsuit$','.','+'],#散点图的marker                 plot_kws=dict(s=50, edgecolor="r", linewidth=1),#非对角线上的图marker大小、外框、外框线宽                 diag_kws=dict(shade=True)#对角线上核密度图是否填充                                                 )g.fig.set_size_inches(12,12)sns.set(font_scale=1.5)

Python中seaborn如何绘制矩阵图

3、seaborn.PairGrid(更灵活的绘制矩阵图)

seaborn.PairGrid(data, hue=None, hue_order=None, palette=None, hue_kws=None, vars=None, x_vars=None, y_vars=None, corner=False, diag_sharey=True, height=2.5, aspect=1, layout_pad=0, despine=True, dropna=True, size=None)

每个子图绘制同类型的图

g = sns.PairGrid(pd_iris,                  hue='class',                 palette='husl',)g = g.map(plt.scatter)#map每个子图绘制一样类型的图g = g.add_legend()g.fig.set_size_inches(12,12)sns.set(style='whitegrid',font_scale=1.5)

Python中seaborn如何绘制矩阵图

对角线和非对角线分别绘制不同类型图

g = sns.PairGrid(pd_iris,                  hue='class',                palette='Set1',)g = g.map_diag(plt.hist)#对角线绘制直方图g = g.map_offdiag(plt.scatter)#非对角线绘制散点图g = g.add_legend()g.fig.set_size_inches(12,12)sns.set(style='whitegrid',font_scale=1.5)

Python中seaborn如何绘制矩阵图

对角线上方、对角线、对角线下方分别绘制不同类型图

g = sns.PairGrid(pd_iris, hue='class',)g = g.map_upper(sns.scatterplot)g = g.map_lower(sns.kdeplot, colors="C0")g = g.map_diag(sns.kdeplot, lw=2)3绘制核密度图g = g.add_legend()#添加图例sns.set(style='whitegrid',font_scale=1.5)

Python中seaborn如何绘制矩阵图

其它一些参数修改

g = sns.PairGrid(pd_iris, hue='class',                 palette='Set1',                 hue_kws={"marker": ["^", "s", "D"]},#设置marker                 diag_sharey=False,                )g = g.map_upper(sns.scatterplot,edgecolor="w", s=40)#设置点大小,外框颜色g = g.map_lower(sns.kdeplot, colors="#01a2d9")#设置下三角图形颜色g = g.map_diag(sns.kdeplot, lw=3)#对角图形颜色g = g.add_legend()#添加图例g.fig.set_size_inches(12,12)sns.set(style='whitegrid',font_scale=1.5)

Python中seaborn如何绘制矩阵图

感谢你能够认真阅读完这篇文章,希望小编分享的“Python中seaborn如何绘制矩阵图”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯