了解下一个流行的 Python 第三方库—Pandas

Crq
Crq
管理员
1466
文章
0
粉丝
Linux教程评论4字数 1134阅读3分46秒阅读模式
摘要Pandas 是一个十分流行的 Python 第三方库。本文介绍了 Pandas 库中的一些特性和函数,并且我们鼓励读者亲手使用 Pandas 库,来解决实际的业务问题。

了解下一个流行的 Python 第三方库—Pandas

Pandas 为 Python 中数据分析提供了基础和高级的构建组件。Pandas 库是用于数据分析与数据操作的最强大和最灵活的开源分析工具之一,并且它还提供了用于建模和操作表格数据(以行和列组织的数据)的数据结构。

Pandas 库有两个主要的数据结构:第一个是 “系列Series”,该数据结构能够很方便地从 Python 数组或字典中按位置或指定的索引名称来检索数据;第二个是“数据帧DataFrames”,该数据结构将数据存储在行和列中。列可以通过列名访问,行通过索引访问。列可以有不同类型的数据,包括列表、字典、序列、数据帧、NumPy 数组等。

Pandas 库可以处理各种文件格式

有各种各样的文件格式。用于数据分析的工具必须能够提供处理各种文件格式的方法。

Pandas 可以读取各种文件格式,例如 CSV 文件、JSON 文件、XML 文件、Parquet 文件、SQL 文件,详见下表。

写入 读取
CSV 文件 to_csv函数 read_csv函数
JSON 文件 to_json函数 read_json函数
Parquet 文件 to_parquet函数 read_parquet函数
SQL 文件 to_sql函数 read_sql函数,read_sql_query函数,read_sql_table函数
XML 文件 to_xml函数 read_xml函数
使用 Pandas 进行数据清理

在现实场景中,很多数据集存在数据缺失、数据格式错误、错误数据或重复数据的情况,如果要对使数据分析更加准确,就需要对这些没有用的数据进行处理。此外,数据还会有需要 屏蔽mask 的敏感和机密信息。接下来,Pandas 提供了清理、丢弃、替换、屏蔽等方法,来处理这些坏数据。

Pandas 清洗空值:
a. 空行可以使用 df.dropna(inplace=True) 方法来删除。

b. 空值可以使用 df.fillna(, inplace=True) 方法来替换。还可以指定某一个列来替换该列的空数据。

Pandas 屏蔽数据:
c. 要屏蔽所有不满足条件 my_list.where(my_list df.drop_duplicates(‘’, keep = False) df.drop_duplicates(‘’, keep = ‘first’) df.drop_duplicates(‘’, keep = ‘last’)

使用 Pandas 进行数据分析

下面的表格列出了 Pandas 中进行数据分析的各种函数,以及其语法。(请注意:df 代表一个 数据帧DataFrame 数据结构的实例。)

语法 描述
df.head(x) head()函数用于读取前面的 x 行,如果不填参数 x,默认返回 5 行
df.tail(x) tail()函数用于读取尾部的 x 行,如果不填参数 x ,默认返回最后 5 行,空行各个字段的值返回 NaN
loc(x:y) Loc 函数返回指定行的数据,也可以对数据进行切片
groupby('<column>') 对指定列的数据进行分组
df['column'].sum() 计算指定列数据的总和
df['column']. mean() 计算指定列数据的算术平均值
df['column'].min() 计算指定列数据的最小值
df['column'].max() 计算指定列数据的最大值
df.sort_values(['column']) 在指定列上根据数值进行排序,默认升序
df.size 返回元素的个数,即为行数 * 列数
df.describe 返回对各列的统计汇总
pd.crosstab(df['column1'], df['column2'], margins = True) 创建column1column2的交叉表
df.duplicated([column1,'column2']) 根据column1column2中的重复值,返回TrueFalse
Pandas 的优点
  1. 支持多索引(层次索引),方便分析多维数据。
  2. 支持数据透视表的创建,堆栈和取消堆栈操作。
  3. 可以使用 Pandas 处理有限值的分类数据。
  4. 支持分组和聚合运算。
  5. 可以禁用排序。
  6. 支持行级过滤(获取满足过滤条件的行)和列级过滤(只选择需要的列)。
  7. 有助于重塑数据集(数组的维度变换)。还可以转置数组的值,并转换为列表。当你使用 Python 处理数据时,可以将 Pandas 数据帧转换为多维 NumPy 数组。
  8. 支持面向标签的数据切片。
Pandas 的不足

Pandas 的代码和语法与 Python 不同,所以人们需要额外再学习 Pandas。此外,相较于 Pandas,像三维数据这样的高维数据会在 NumPy 等其他库有更好的处理。

总结

Pandas 能够大幅提升数据分析的效率。它与其他库的兼容性使它在其他 Python 库中都能有效地使用。

weinxin
我的微信
微信号已复制
我的微信
这是我的微信扫一扫
 
Crq
  • 本文由 Crq 发表于2025年1月21日 18:10:41
  • 转载请注明:https://www.cncrq.com/12704.html
详解shell语法检查模式 Linux教程

详解shell语法检查模式

启用 verbose 调试模式 在进入本指导的重点之前,让我们简要地探索下 verbose 模式。它可以用 -v 调试选项来启用,它会告诉 shell 在读取时显示每行。要展示这个如何工作,下面是一个...
五原则之监控微服务 Linux教程

五原则之监控微服务

我们对微服务的需求可以归纳为一个词:速度。这种更快提供功能完善且可靠的软件的需求,彻底改变了软件开发模式。毫无疑问,这个改变对软件管理,包括系统监控的方式,都产生了影响。在这篇文章...
匿名

发表评论

匿名网友
:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:
确定

拖动滑块以完成验证