当前位置: 代码网 > it编程>前端脚本>Python > Python使用Matplotlib和Seaborn进行数据可视化分析

Python使用Matplotlib和Seaborn进行数据可视化分析

2025年12月08日 Python 我要评论
1. 引言:数据可视化的力量在当今数据爆炸的时代,我们每天都面临着海量信息。如何从这些原始数据中提取有价值的洞察,并将其清晰、有效地传达给他人?答案就是——数据可视化。数据可视

1. 引言:数据可视化的力量

在当今数据爆炸的时代,我们每天都面临着海量信息。如何从这些原始数据中提取有价值的洞察,并将其清晰、有效地传达给他人?答案就是——数据可视化

数据可视化是将数据以图形或图像的形式呈现,帮助我们理解数据模式、趋势、异常值和关系。它不仅仅是美化数据,更是数据分析不可或缺的一环。一张精心设计的图表,往往胜过千言万语,能让我们一眼洞察数据背后的故事。

python作为数据科学领域的明星语言,拥有强大且丰富的可视化库,其中最著名的莫过于 matplotlibseaborn

  • matplotlib 是python最基础也是最核心的绘图库,它提供了非常灵活的绘图接口,可以绘制各种静态、动态、交互式的图表。虽然其默认样式可能略显朴素,但通过精细的控制,可以创建出任何你想要的图表。
  • seaborn 是基于matplotlib的高级统计图表库,它提供了更美观的默认样式和更高级的统计图表类型,特别适合进行探索性数据分析。seaborn让绘制复杂且具有统计学意义的图表变得更加简单快捷。

本篇博客将作为数据可视化之旅的起点,手把手带领完全新手读者,从零开始学习如何使用matplotlib和seaborn绘制常用图表,并掌握一些基本的图表定制技巧。

2. 前置知识与环境准备

在开始绘图之前,请确保您的python环境中已安装必要的库。

2.1. 必备知识

  • python基础: 对python语法、数据类型(列表、字典)、循环、函数等有基本了解。
  • pandas基础: 对dataframe数据结构有基本认识,知道如何创建、选择和过滤数据。

2.2. 安装所需库

如果您尚未安装 pandas, matplotlibseaborn,可以使用 pip 命令进行安装:

pip install pandas matplotlib seaborn

2.3. 推荐开发环境

为了获得最佳的学习体验,我们强烈建议您使用 jupyter notebookjupyterlab。它们提供了交互式的代码执行环境,可以即时看到绘图结果,非常适合数据探索和可视化。

如果您使用vs code等ide,也可以直接运行python脚本。

3. 分步指南:从基础到进阶的图表绘制

我们将首先从matplotlib的基础图表开始,然后过渡到seaborn更高级和美观的图表。

3.1. 导入必要的库

在任何绘图代码的开头,通常都需要导入这些库:

import pandas as pd
import numpy as np # numpy常用于生成数值数据
import matplotlib.pyplot as plt
import seaborn as sns

# 设置matplotlib中文显示,防止乱码
plt.rcparams['font.sans-serif'] = ['simhei'] # 指定默认字体
plt.rcparams['axes.unicode_minus'] = false # 解决保存图像时负号'-'显示为方块的问题

小贴士: plt.rcparams 的设置是为了让matplotlib能够正确显示中文标签和负号。如果您是在英文环境下,可以忽略此设置。

3.2. 准备示例数据

为了演示,我们先创建一些简单的数据。

# 创建一个简单的dataframe
data = {
    '月份': ['一月', '二月', '三月', '四月', '五月', '六月'],
    '销售额': [150, 200, 180, 220, 250, 230],
    '成本': [100, 120, 110, 130, 140, 135],
    '利润': [50, 80, 70, 90, 110, 95],
    '产品a销量': [30, 45, 40, 50, 60, 55],
    '产品b销量': [20, 30, 25, 35, 40, 38],
    '评分': [75, 80, 85, 70, 90, 88]
}
df = pd.dataframe(data)
print("示例dataframe:")
print(df)

# 创建一些用于直方图和饼图的额外数据
np.random.seed(42) # 为了结果可复现
scores = np.random.normal(loc=75, scale=10, size=100) # 模拟100个考试分数
categories = ['电子产品', '服装', '食品', '家居', '图书']
sales_by_category = [400, 300, 200, 150, 100]

3.3. matplotlib基础绘图

matplotlib的绘图流程通常是:plt.figure() (创建画布,可选) -> plt.plot()/plt.scatter()/... (绘制图表) -> plt.title()/plt.xlabel()/... (添加标题和标签) -> plt.show() (显示图表)。

3.3.1. 折线图 (line plot)

用途: 展现数据随时间或其他连续变量变化的趋势。

plt.figure(figsize=(10, 6)) # 设置图表大小
plt.plot(df['月份'], df['销售额'], marker='o', linestyle='-', color='skyblue', label='销售额')
plt.plot(df['月份'], df['成本'], marker='x', linestyle='--', color='salmon', label='成本')

plt.title('月度销售额与成本趋势')
plt.xlabel('月份')
plt.ylabel('金额 (万元)')
plt.grid(true, linestyle='--', alpha=0.7) # 添加网格线
plt.legend() # 显示图例
plt.show()

3.3.2. 散点图 (scatter plot)

用途: 探索两个数值变量之间的关系,判断是否存在相关性。

plt.figure(figsize=(8, 6))
plt.scatter(df['销售额'], df['利润'], color='purple', alpha=0.7)

plt.title('销售额与利润关系散点图')
plt.xlabel('销售额 (万元)')
plt.ylabel('利润 (万元)')
plt.grid(true, linestyle=':', alpha=0.6)
plt.show()

3.3.3. 柱状图 (bar plot)

用途: 比较不同类别之间的数据大小。

plt.figure(figsize=(10, 6))
plt.bar(df['月份'], df['产品a销量'], color='lightgreen', label='产品a销量')
plt.bar(df['月份'], df['产品b销量'], bottom=df['产品a销量'], color='lightcoral', label='产品b销量') # 堆叠柱状图

plt.title('月度产品销量对比')
plt.xlabel('月份')
plt.ylabel('销量 (件)')
plt.legend()
plt.show()

3.3.4. 直方图 (histogram)

用途: 显示数值数据的分布情况,了解数据集中在哪个范围,以及分布的形状。

plt.figure(figsize=(8, 6))
plt.hist(scores, bins=10, color='teal', edgecolor='black', alpha=0.7) # bins参数控制分组数量

plt.title('学生考试分数分布')
plt.xlabel('分数')
plt.ylabel('人数')
plt.grid(axis='y', linestyle='--', alpha=0.7)
plt.show()

3.3.5. 饼图 (pie chart)

用途: 展现各部分在整体中所占的比例。

plt.figure(figsize=(8, 8))
plt.pie(sales_by_category, labels=categories, autopct='%1.1f%%', startangle=90, colors=sns.color_palette('pastel'))
# autopct='%1.1f%%' 显示百分比
# startangle=90 从90度开始逆时针绘制
# colors=sns.color_palette('pastel') 使用seaborn的调色板让饼图更美观

plt.title('各产品类别销售额占比')
plt.axis('equal') # 保证饼图是正圆
plt.show()

3.3.6. 图表定制化总结

matplotlib提供了丰富的定制选项:

  • plt.figure(figsize=(width, height)): 创建一个指定大小的画布。
  • plt.title('标题'): 设置图表主标题。
  • plt.xlabel('x轴标签'), plt.ylabel('y轴标签'): 设置坐标轴标签。
  • plt.xticks(), plt.yticks(): 设置坐标轴刻度。
  • plt.grid(true): 添加网格线。
  • plt.legend(): 显示图例。
  • plt.xlim(), plt.ylim(): 设置坐标轴范围。
  • color='...', marker='...', linestyle='...', alpha=...: 控制线条颜色、标记、样式和透明度。
  • plt.savefig('my_plot.png'): 保存图表到文件。

3.4. seaborn增强绘图

seaborn在matplotlib的基础上进行了封装,提供了更高级的api和更美观的默认样式,尤其擅长绘制统计图表。

为了更好地展示seaborn的特性,我们加载一个seaborn自带的经典数据集 tips

# 加载seaborn自带数据集
tips = sns.load_dataset('tips')
print("\nseaborn 'tips' 数据集:")
print(tips.head())

3.4.1. 关系图 (relational plots)

seaborn的 relplot() 可以方便地创建散点图和折线图,并支持通过 col, row, hue, size, style 等参数创建多维度视图。

散点图 (scatterplot)

plt.figure(figsize=(10, 6))
sns.scatterplot(x='total_bill', y='tip', hue='time', style='smoker', size='size', data=tips)
plt.title('用餐总金额与小费关系 (按用餐时间与吸烟者区分)')
plt.xlabel('用餐总金额 ($)')
plt.ylabel('小费 ($)')
plt.grid(true, linestyle='--', alpha=0.6)
plt.show()

3.4.2. 分布图 (distribution plots)

直方图 (histplot)

plt.figure(figsize=(10, 6))
sns.histplot(data=tips, x='total_bill', kde=true, hue='sex', palette='viridis')
# kde=true 会在直方图上叠加核密度估计曲线
# hue='sex' 按性别进行分组显示
plt.title('用餐总金额分布 (按性别)')
plt.xlabel('用餐总金额 ($)')
plt.ylabel('计数')
plt.show()

核密度估计图 (kdeplot)

plt.figure(figsize=(10, 6))
sns.kdeplot(data=tips, x='total_bill', hue='time', fill=true, palette='coolwarm')
plt.title('用餐总金额核密度估计 (按用餐时间)')
plt.xlabel('用餐总金额 ($)')
plt.ylabel('密度')
plt.show()

3.4.3. 分类图 (categorical plots)

柱状图 (barplot)

plt.figure(figsize=(10, 6))
sns.barplot(x='day', y='total_bill', hue='sex', data=tips, palette='deep')
plt.title('每日用餐总金额均值 (按性别)')
plt.xlabel('星期几')
plt.ylabel('用餐总金额均值 ($)')
plt.show()

计数图 (countplot)

plt.figure(figsize=(8, 6))
sns.countplot(x='day', hue='time', data=tips, palette='pastel')
plt.title('每日用餐次数 (按用餐时间)')
plt.xlabel('星期几')
plt.ylabel('用餐次数')
plt.show()

箱线图 (boxplot)

用途: 显示数值数据的五数概括(最小值、下四分位数、中位数、上四分位数、最大值)和异常值。

plt.figure(figsize=(10, 6))
sns.boxplot(x='day', y='total_bill', hue='smoker', data=tips, palette='muted')
plt.title('每日用餐总金额分布 (按吸烟者)')
plt.xlabel('星期几')
plt.ylabel('用餐总金额 ($)')
plt.show()

小提琴图 (violinplot)

用途: 结合了箱线图和核密度估计图的特点,更详细地展示数据的分布形状。

plt.figure(figsize=(10, 6))
sns.violinplot(x='day', y='tip', hue='sex', data=tips, palette='viridis', inner='quartile')
# inner='quartile' 显示四分位数线
plt.title('每日小费金额分布 (按性别)')
plt.xlabel('星期几')
plt.ylabel('小费 ($)')
plt.show()

3.4.4. 热力图 (heatmap)

用途: 可视化矩阵数据,尤其适用于展示相关性矩阵。

# 计算tips数据集中数值列的相关性矩阵
correlation_matrix = tips[['total_bill', 'tip', 'size']].corr()

plt.figure(figsize=(8, 7))
sns.heatmap(correlation_matrix, annot=true, cmap='coolwarm', fmt=".2f", linewidths=.5)
# annot=true 在热力图上显示数值
# cmap='coolwarm' 设置颜色映射
# fmt=".2f" 格式化数值为两位小数
plt.title('用餐数据数值变量相关性热力图')
plt.show()

4. 常见陷阱与注意事项

作为初学者,在进行数据可视化时容易犯一些错误。了解这些陷阱可以帮助您创建更有效、更准确的图表。

1.选择错误的图表类型:

  • 错误: 用饼图展示多个类别之间的趋势(饼图只适合展示部分与整体的比例,类别过多或需要看趋势时应避免)。
  • 正确: 趋势用折线图,比较用柱状图,分布用直方图/kde图,关系用散点图。

2.图表信息不完整:

  • 陷阱: 缺少标题、x/y轴标签、单位,或者图例不清晰。
  • 解决方案: 始终为图表添加清晰、描述性的标题和标签,确保读者无需额外解释就能理解图表内容。

3.数据量过大导致重叠 (overplotting):

  • 陷阱: 在散点图中,如果数据点过多,它们会相互重叠,导致无法看清 真实分布。
  • 解决方案: 考虑使用透明度 (alpha 参数),或者使用 hexbin 图、2d核密度估计图(sns.kdeplot(..., kind='hist'))等替代方案。

4.误导性可视化:

  • 陷阱: 坐标轴没有从零开始,或者坐标轴范围设置不当,可能夸大或缩小数据的差异。
  • 解决方案: 除非有充分理由,否则y轴通常应从零开始。谨慎设置坐标轴范围,确保真实反映数据。

5.颜色选择不当:

  • 陷阱: 使用过多颜色,或者颜色对比度不足,导致图表难以阅读,特别是对于色盲用户。
  • 解决方案: 优先使用seaborn提供的调色板,它们通常经过优化。对于分类数据,选择区分度高的颜色;对于连续数据,选择渐变色。

5. 资源与总结

恭喜您!通过本篇博客的学习,您已经掌握了python数据可视化的基础知识,并能够使用matplotlib和seaborn绘制多种常用图表。

5.1. 进一步学习资源

  • matplotlib 官方文档: https://matplotlib.org/ (最权威、最全面的参考资料)
  • seaborn 官方文档: https://seaborn.pydata.org/ (提供大量示例和详细解释)
  • python数据科学手册 (python data science handbook): 一本非常优秀的入门书籍,其中有专门的matplotlib章节。
  • kaggle learn: 提供免费的交互式课程,包括数据可视化部分。

5.2. 总结

数据可视化是一项实践性很强的技能。要真正掌握它,需要不断地练习和尝试。从简单的数据集开始,尝试绘制不同类型的图表,并不断调整参数和样式,直到您能自信地用图表讲述数据的故事。

记住,好的可视化不仅仅是代码的堆砌,更是对数据洞察的艺术表达。祝您在数据可视化的旅程中取得丰硕的成果!

以上就是python使用matplotlib和seaborn进行数据可视化分析的详细内容,更多关于python数据可视化的资料请关注代码网其它相关文章!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com