使用 Pandas 进行数据可视化:综合指南
liuian 2025-04-09 17:48 16 浏览
使用 Pandas 创建基本图:线图、散点图、条形图、直方图、箱线图和面积图
介绍
数据可视化是数据和信息的图形表示。它是理解复杂数据和与他人交流见解的强大工具。数据可视化可用于多种目的,例如识别趋势、模式和异常值,以及探索变量之间的关系。
Pandas 是一个流行的 Python 开源数据分析库。它提供了强大的数据结构和数据分析工具,包括数据可视化功能。Pandas 可视化建立在 matplotlib 库之上,该库提供了广泛的可自定义绘图。
在本文中,我们将探索使用 pandas 进行数据可视化的基础知识。 我们将从简单的图表开始,逐步进行更复杂的可视化。 我们还将介绍创建有效可视化和自定义 pandas 图的最佳实践。
设置 Pandas 和数据
在我们开始使用 pandas 可视化数据之前,我们需要安装 pandas 并将数据加载到 pandas DataFrame 中。
安装 Pandas
如果您还没有安装 pandas,可以使用 Python 包管理器 pip。 打开终端或命令提示符并运行以下命令:
pip install pandas
导入库
安装 pandas 后,您可以在 Python 脚本中导入它和其他必要的库。
import pandas as pd
加载数据
要将数据加载到 pandas DataFrame 中,我们可以使用 pd.read_csv() 函数。此函数读取 CSV 文件并创建 DataFrame 对象。
df = pd.read_csv('https://raw.githubusercontent.com/pycaret/pycaret/master/datasets/diamond.csv')
df.head()
df.describe()
这将为 DataFrame 中的每一列打印统计信息,例如计数、平均值和标准差。这些函数对于在我们开始可视化之前快速了解我们的数据很有用。
使用 Pandas plot 方法进行可视化
Pandas 提供了几种基本的可视化技术,使我们能够快速可视化我们的数据。 在本节中,我们将介绍 pandas 中一些最常用的绘图。
线图
线图是将数据显示为由线连接的一系列点的图形。我们可以使用 plot() 函数在 pandas 中创建一个线图,并将 kind 参数设置为“line”:
# 导入 pandas 库
import pandas as pd
# 使用 pandas 从 URL 读取 migration.csv 数据
df = pd.read_csv('https://raw.githubusercontent.com/pycaret/pycaret/master/datasets/migration.csv')
# 转置 DataFrame,使国家位于列中
df = df.transpose()
# 将列名设置为 DataFrame 第一行中的值
df.columns = df.iloc[0]
# 删除该行带有列名
df = df.drop(index = 'Country Name')
# 将索引重命名为 'Year'
df = df.rename_axis('Year')
# 绘制加拿大的移民数据
df['Canada'].plot()
输出:
在这里,我们在 DataFrame 中创建了 Canada 列与 Year 列的线图。
散点图
散点图是将两个变量之间的关系显示为一系列点的图形。我们可以使用 plot() 函数在 pandas 中创建一个散点图,并将 kind 参数设置为“scatter”:
# 导入 pandas 库
import pandas as pd
# 使用 pandas 从 URL 读取 diamond.csv 数据
df = pd.read_csv('https://raw.githubusercontent.com/pycaret/pycaret/master/datasets/diamond.csv')
# 重量和价格的散点图
df.plot(kind='scatter', x='Carat Weight', y='Price')
输出:
在这里,我们在 DataFrame 中创建了 Price 列与 Carat Weight 列的散点图。
条形图
条形图是用矩形条显示分类数据的图表。 我们可以使用 kind 参数设置为 bar 的 plot 函数在 pandas 中创建条形图:
# 导入 pandas 库
import pandas as pd
# 使用 pandas 从 URL 读取 diamond.csv 数据
df = pd.read_csv('https://raw.githubusercontent.com/pycaret/pycaret/master/datasets/diamond.csv')
# 按切割类型绘制钻石数量的条形图
df['Cut'].value_counts().plot(kind = 'bar')
输出:
在这里,我们创建了一个按切工类型划分的钻石数量条形图。
直方图
直方图是显示数值变量分布的图表。 我们可以使用 kind 参数设置为 hist 的 plot 函数在 pandas 中创建直方图:
# 导入 pandas 库
import pandas as pd
# 使用 pandas 从 URL 读取 diamond.csv 数据
df = pd.read_csv('https://raw.githubusercontent.com/pycaret/pycaret/master/datasets/diamond.csv')
# 价格直方图
df['Price'].plot(kind = 'hist')
输出:
在这里,我们在 DataFrame 中创建价格列的直方图。
箱线图
箱线图是显示数值变量分布的图形。 我们可以使用 kind 参数设置为 box 的 plot 函数在 pandas 中创建一个箱线图:
# 导入 pandas 库
import pandas as pd
# 使用 pandas 从 URL 读取 diamond.csv 数据
df = pd.read_csv('https://raw.githubusercontent.com/pycaret/pycaret/master/datasets/diamond.csv')
# 价格直方图
df['Price'].plot(kind = 'box')
输出:
面积图
面积图是显示不同变量的数值随时间或任何其他维度的演变的图表。 我们可以使用 kind 参数设置为 area 的 plot 函数在 pandas 中创建面积图:
# 导入 pandas 库
import pandas as pd
# 使用 pandas 从 URL 读取 migration.csv 数据
df = pd.read_csv('https://raw.githubusercontent.com/pycaret/pycaret/master/datasets/migration.csv')
# 转置 DataFrame,使国家位于列中
df = df.transpose()
# 将列名设置为 DataFrame 第一行中的值
df.columns = df.iloc[0]
# 删除该行带有列名
df = df.drop(index = 'Country Name')
# 将索引重命名为 'Year'
df = df.rename_axis('Year')
# 绘制加拿大和美国的移民数据
df[['Canada', 'United States']].plot(kind = 'area')
输出:
结论
在本文中,我们学习了如何使用 pandas 创建各种类型的图表和可视化来探索和分析数据。我们已经介绍了一些基本的可视化技术,例如线图、散点图、条形图、直方图、箱线图和面积图。
Pandas 提供了一种强大而灵活的方法,只需几行代码即可创建可视化效果。借助 pandas,我们可以轻松地以可视化方式探索和分析我们的数据,并深入了解潜在的模式和趋势。我们希望本文对使用 pandas 进行数据可视化对您有所帮助。
相关推荐
- 深入解析 MySQL 8.0 JSON 相关函数:解锁数据存储的无限可能
-
引言在现代应用程序中,数据的存储和处理变得愈发复杂多样。MySQL8.0引入了丰富的JSON相关函数,为我们提供了更灵活的数据存储和检索方式。本文将深入探讨MySQL8.0中的JSON...
- MySQL的Json类型个人用法详解(mysql json类型对应java什么类型)
-
前言虽然MySQL很早就添加了Json类型,但是在业务开发过程中还是很少设计带这种类型的表。少不代表没有,当真正要对Json类型进行特定查询,修改,插入和优化等操作时,却感觉一下子想不起那些函数怎么使...
- MySQL的json查询之json_array(mysql json_search)
-
json_array顾名思义就是创建一个数组,实际的用法,我目前没有想到很好的使用场景。使用官方的例子说明一下吧。例一selectjson_array(1,2,3,4);json_array虽然单独...
- 头条创作挑战赛#一、LSTM 原理 长短期记忆网络
-
#头条创作挑战赛#一、LSTM原理长短期记忆网络(LongShort-TermMemory,LSTM)是一种特殊类型的循环神经网络(RNN),旨在解决传统RNN在处理长序列数据时面临的梯度...
- TensorBoard最全使用教程:看这篇就够了
-
机器学习通常涉及在训练期间可视化和度量模型的性能。有许多工具可用于此任务。在本文中,我们将重点介绍TensorFlow的开源工具套件,称为TensorBoard,虽然他是TensorFlow...
- 图神经网络版本的Kolmogorov Arnold(KAN)代码实现和效果对比
-
本文约4600字,建议阅读10分钟本文介绍了图神经网络版本的对比。KolmogorovArnoldNetworks(KAN)最近作为MLP的替代而流行起来,KANs使用Kolmogorov-Ar...
- kornia,一个实用的 Python 库!(python kkb_tools)
-
大家好,今天为大家分享一个实用的Python库-kornia。Github地址:https://github.com/kornia/kornia/Kornia是一个基于PyTorch的开源计算...
- 图像分割掩码标注转YOLO多边形标注
-
Ultralytics团队付出了巨大的努力,使创建自定义YOLO模型变得非常容易。但是,处理大型数据集仍然很痛苦。训练yolo分割模型需要数据集具有其特定格式,这可能与你从大型数据集中获得的...
- [python] 向量检索库Faiss使用指北
-
Faiss是一个由facebook开发以用于高效相似性搜索和密集向量聚类的库。它能够在任意大小的向量集中进行搜索。它还包含用于评估和参数调整的支持代码。Faiss是用C++编写的,带有Python的完...
- 如何把未量化的 70B 大模型加载到笔记本电脑上运行?
-
并行运行70B大模型我们已经看到,量化已经成为在低端GPU(比如Colab、Kaggle等)上加载大型语言模型(LLMs)的最常见方法了,但这会降低准确性并增加幻觉现象。那如果你和你的朋友们...
- ncnn+PPYOLOv2首次结合!全网最详细代码解读来了
-
编辑:好困LRS【新智元导读】今天给大家安利一个宝藏仓库miemiedetection,该仓库集合了PPYOLO、PPYOLOv2、PPYOLOE三个算法pytorch实现三合一,其中的PPYOL...
- 人工智能——图像识别(人工智能图像识别流程)
-
概述图像识别(ImageRecognition)是计算机视觉的核心任务之一,旨在通过算法让计算机理解图像内容,包括分类(识别物体类别)、检测(定位并识别多个物体)、分割(像素级识别)等,常见的应用场...
- PyTorch 深度学习实战(15):Twin Delayed DDPG (TD3) 算法
-
在上一篇文章中,我们介绍了DeepDeterministicPolicyGradient(DDPG)算法,并使用它解决了Pendulum问题。本文将深入探讨TwinDelayed...
- 大模型中常用的注意力机制GQA详解以及Pytorch代码实现
-
分组查询注意力(GroupedQueryAttention)是一种在大型语言模型中的多查询注意力(MQA)和多头注意力(MHA)之间进行插值的方法,它的目标是在保持MQA速度的同时...
- pytorch如何快速创建具有特殊意思的tensor张量?
-
专栏推荐正文我们通过值可以看到torch.empty并没有进行初始化创建tensor并进行随机初始化操作,常用rand/rand_like,randint正态分布(0,1)指定正态分布的均值还有方差i...
- 一周热门
-
-
Python实现人事自动打卡,再也不会被批评
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
python使用fitz模块提取pdf中的图片
-
《人人译客》如何规划你的移动电商网站(2)
-
Jupyterhub安装教程 jupyter怎么安装包
-
- 最近发表
-
- 深入解析 MySQL 8.0 JSON 相关函数:解锁数据存储的无限可能
- MySQL的Json类型个人用法详解(mysql json类型对应java什么类型)
- MySQL的json查询之json_array(mysql json_search)
- 头条创作挑战赛#一、LSTM 原理 长短期记忆网络
- TensorBoard最全使用教程:看这篇就够了
- 图神经网络版本的Kolmogorov Arnold(KAN)代码实现和效果对比
- kornia,一个实用的 Python 库!(python kkb_tools)
- 图像分割掩码标注转YOLO多边形标注
- [python] 向量检索库Faiss使用指北
- 如何把未量化的 70B 大模型加载到笔记本电脑上运行?
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- table.render (33)
- uniapp textarea (33)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- react-admin (33)
- vscode切换git分支 (35)
- vscode美化代码 (33)
- python bytes转16进制 (35)