seaborn 是用于数据分布可视化的强大工具,常用函数包括 histplot、kdeplot、boxplot 等。1. 安装 seaborn 后需导入相关库;2. 使用 histplot 替代旧版 distplot 可绘制直方图并叠加密度曲线;3. kdeplot 专用于绘制平滑密度曲线,支持二维 kde 图;4. boxplot 和 violinplot 分别用于识别异常值及展示复杂分布形态;5. pairplot 可快速查看多变量分布及相关性,提升数据分析效率。掌握这些函数及其参数设置,有助于制作清晰美观的统计图表。
数据分析中最常见的需求之一就是了解数据的分布情况,而用图表来展示这种分布是最直观的方式。Seaborn 是 Python 中一个非常实用的统计可视化库,它基于 Matplotlib,封装了大量常用统计图表的绘制方法,尤其在展示数据分布方面非常强大。
如果你还没安装 Seaborn,可以通过 pip 快速安装:
pip install seaborn
安装完成后,一般还会导入相关的库,比如 matplotlib.pyplot 和 pandas,因为 Seaborn 很多时候是配合这些库一起使用的。
立即学习“Python免费学习笔记(深入)”;
import seaborn as sns import matplotlib.pyplot as plt import pandas as pd
建议使用 Jupyter Notebook 或者类似的交互式环境,这样可以在运行代码后直接看到图像输出。
Seaborn 早期版本中常用的函数是 distplot(),它可以快速画出一个变量的直方图,并叠加核密度估计曲线。
sns.distplot(data) plt.show()
注意:从 Seaborn 0.11 开始,distplot() 已被弃用,取而代之的是更明确的两个函数:histplot() 和 kdeplot()。
如果你想画直方图并加上密度曲线,可以使用 histplot() 并设置参数 kde=True。
sns.histplot(data, kde=True) plt.show()
这个函数支持更多自定义选项,例如调整 bins 数量、颜色、透明度等:
如果你只想显示密度曲线而不显示直方图,可以把 stat='density' 和 bins=0 结合使用。
如果你不关心直方图,只想看平滑的密度曲线,可以用 kdeplot():
sns.kdeplot(data) plt.show()
它也支持双变量密度图(即二维 KDE 图),只需要传入两个变量:
sns.kdeplot(x=x_data, y=y_data) plt.show()
这在分析两个变量之间的联合分布时非常有用。
除了直方图和密度图之外,箱型图(boxplot)和小提琴图(violinplot)也能帮助我们了解数据分布的特点,尤其是识别异常值。
sns.boxplot(x=data) plt.show() sns.violinplot(x=data) plt.show()
当你面对多个变量时,想快速看看它们各自的分布以及两两之间的关系,可以用 pairplot():
df = pd.DataFrame(...) # 假设这是一个包含多个列的 DataFrame sns.pairplot(df) plt.show()
这个函数会自动为每个变量画出直方图,并在交叉处画出散点图或回归线图(如果指定 kind='reg')。
基本上就这些。掌握这几个函数,你就能用 Seaborn 轻松地分析数据分布了。其实也不复杂,但容易忽略的是参数的灵活搭配,比如颜色、透明度、坐标轴设置等,这些细节能让图表更清晰、美观。
以上就是Python如何分析数据分布—seaborn统计可视化教程的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号