pandas 删除列_教你使用Python和Pandas的最简单的数据清理方法

63657ac98625bc958d05664e9ff2ac79.png

在本文中,我们将学习如何使用Python包Pyjanitor简化数据预处理工作。具体来说,我们将学习如何:

  • 向一个Pandasdataframe(数据帧)中添加一个列
  • 删除缺失的值
  • 删除一个空列
  • 清洗列名称

也就是说,我们将学习如何使用Pyjanitor清理Pandas数据帧。在所有Python数据操作示例中,我们还将看到如何仅使用Pandas的功能来实现这些操作。

Pyjanitor是什么?

Pyjanitor是什么?在我们继续学习如何使用Pandas和Pyjanitor来清理数据集之前,我们将学习这个包。Python包Pyjanitor使用基于文本的API扩展了Pandas。这个易于使用的API为我们提供了方便的数据清理技术。显然,它一开始是R包 janitor的一部分。此外,它的灵感来自于R包 dplyr的易用性和表现力。注意,有一些不同的方式可以使用这些方法,本文不会涵盖所有方式(请参阅文档:https://pyjanitor.readthedocs.io/ )。

如何安装 Pyjanitor

有两种比较容易的方法来安装Pyjanitor:

1.使用Pip安装Pyjanitor

da897c89cedd23e168993eec6cf20951.png

2.使用Conda安装Pyjanitor:

dd1b8fa1100ae76193c80db136cee2c7.png

既然我们已经知道了Pyjanitor是什么以及如何安装这个包,那我们很快就可以继续学习Python数据清理教程了,学习如何从Pandas中删除缺失的值。注意,本Pandas教程将详细介绍如何使用Pandas和Pyjanitor来实现这一点。最后,我们将有一个完整的只使用Pyjanitor的数据清理示例和一个链接到包含所有代码的Jupyter Notebook的链接。

  • 使用Pandas进行数据操作:简明教程(https://www.marsja.se/data-manipulation-pandas-tutorial/ )

假数据

在第一个Python数据操作示例中,我们将使用一个假数据集。更具体地说,我们将创建一个数据帧,其中有一个空列和一些缺失的值。在本文的这一部分中,我们将进一步使用Python包SciPy和NumPy。也就是说,我们还需要安装这些包。

在这个例子中,我们要创建三个列;Subject, RT (响应时间)和 Deg。要创建响应时间列,我们将使用SciPy的norm来创建正态分布的数据。

4db595a94872462e058b6d182918893f.png

使用Scipy创建Python正态分布

在下一个代码块中,我们使用正态分布为响应时间创建一个变量。

4bfbfd44fffbe4c6011dd1ec71d3d588.png

重新排列列表并添加缺失的值

此外,我们再添加一些缺失的值,并重新排列正态分布的数据列表:

d7c435e43812426622f647c8afd87df8.png

从字典创建数据帧

最后,我们将为我们的两个变量创建一个字典,并使用该字典来创建一个Pandas数据帧:

9af368c4cf2ca530036eb26f0df084fe.png
5620780b6bb39605c4929c6b4e35e89a.png

从字典创建DataFrame

在Python中使用Pandas和Pyjanitor进行数据清理

如何向Pandas Dataframe添加一个列

现在我们已经从一个字典创建了我们的数据帧,我们准备向它添加一个列。在下面的示例中,我们将使用Pandsa和Pyjanitors方法。

1. 向Pandas Dataframe追加一个列

使用Pandas向一个数据帧添加一个列是非常容易的。在下面的例子中,我们将向Pandas 数据帧中追加一个空列:

d2ebd7ffe17c18d15469375714058def.png
791f50301b2cb80db386a6e5508f498c.png

向数据帧中添加列

2. 使用Pyjanitor向Pandas Dataframe添加一个列

现在,我们将使用add_column方法向该数据帧中追加一个列。添加一个空列不像使用上面的方法那么容易。然而,正如您将在本文末尾看到的,我们可以在创建我们的数据帧时使用所有方法:

8350873d58cad809da3683cc9d564761.png
b67ee50cf9c396faff08c4891fa04e29.png

向数据帧中追加列

如何删除Pandas Dataframe中的缺失值

我们的数据集远远不够完整,这是很常见的。这可能是由于测量仪器的错误,人们忘记或拒绝回答某些问题,以及许多其他事情。尽管缺失的信息背后有各种原因,但这些行被称为缺失值。在Pandas的框架中,缺失值由符号NA编码,这与在R统计环境中很像。Pandas有isna()函数来帮助我们识别数据集中的缺失值。如果我们想删除缺失值,Pandas有一个函数dropna()。

1.使用Pandas dropna方法删除缺失值

在下面的代码示例中,我们删除所有具有缺失值的行。注意,如果我们想修改该数据帧,我们应该添加inplace参数并将其设置为true。

dd2584fba81a08d840f6826ad50617f7.png
c4aceb2d54a11949176a398336e6d288.png

2.使用PyJanitor从Pandas Dataframe中删除缺失值

使用Pyjanitor从Pandas Dataframe中删除缺失值的方法与上面的方法相同。也就是说,我们将使用dropna方法。但是,当我们使用Pyjanitor从该数据帧中删除缺失数据时,我们还会使用subset参数来选择要使用哪些列:

be47ea47288ad5037259a649de926363.png

如何从Pandas Dataframe中删除一个空列

在下一个Pandas数据操作示例中,我们将从数据帧中删除空列。首先,我们将使用Pandas删除空列,然后,我们将使用Pyjanitor。请记住,在本文的最后,我们将有一个完整的示例,其中我们在实际创建Pandas Dataframe的同时对所有数据进行清理。

1. 从Pandas Dataframe中删除一个空列

当我们想删除一个空列(例如,带有缺失值)时,我们将再次使用Pandas的dropna方法。然而,我们还将使用axis方法并将其设置为1(针对列)。此外,我们还必须使用参数how并将其设置为' all '。如果我们不这样做,它将删除任何带有缺失值的列。

dff9df7becceffb023ca900fcf6d0392.png
5620780b6bb39605c4929c6b4e35e89a.png

删除空列

2. 使用Pyjanitor从Pandas Dataframe中删除一个空列

使用Pyjanitor删除一个空列要更容易一点:

c52238bddd744b16c4dc0c38a6081aed.png

如何在Pandas Dataframe中重命名列

现在我们知道了如何删除缺失值、向一个Pandas 数据帧中添加一个列以及如何删除一个列,我们将继续这个数据清理教程来学习如何重命名列。

例如,在我们学习了《如何将数据从一个JSON文件加载到一个Pandas数据帧》的文章中,我们重新命名了列,以便稍后更容易地使用该数据帧。在下面的示例中,我们将读取一个JSON文件,并使用Pandas 数据帧方法rename和Pyjanitor来重命名列。

55d674e638a77e736841b32d9a210702.png
662d87dbe368b7c286d7f7facd1e1614.png

更多关于将数据加载到数据帧的文章:

  • 如何使用Python和Pandas读写JSON文件 https://www.marsja.se/how-to-read-and-write-json-files-using-python-and-pandas/
  • Pandas读取CSV教程 https://www.marsja.se/pandas-read-csv-tutorial-to-csv/
  • Pandas Excel教程:如何读写Excel文件 https://www.marsja.se/pandas-excel-tutorial-how-to-read-and-write-excel-files/

1.在Pandas Dataframe中重命名列

如上图所示,我们想要删除一些空格和特殊字符。在第一个重命名列的例子中,我们将使用Pandas的 rename方法和正则表达式一起来重命名列(即,我们将用下划线替换空格和)。

67a2dbc6a81888815a8c3885b5847480.png

2. 如何使用Pyjanitor和clean_names重命名列

使用Pyjanitor重命名一个列(或多个列)要容易得多。实际上,当我们导入了这个Python包之后,我们就可以使用clean_names方法,它将给出与使用Pandas的rename方法相同的结果。事实上,使用clean_names,我们还可以将列名称中的所有字母转换为小写:

f85eae9627629edeb031e2b205759467.png

当从磁盘加载数据时,如何清理数据

使用Pyjanitor清理我们的数据的一个很酷的地方是,我们可以在加载数据时使用上述所有方法。例如,在最后一个数据清理示例中,我们将向该数据帧添加一个列,删除空列,删除缺失的数据,并清理列名称。这就是与Pyjanitor一起工作使我们的生活更容易的原因。

0bca1f9c684124ef663ff70ed332ad88.png
aece1d8e4eb93d717044219a0e846505.png

使用Pyjanitor聚合数据

在最后一个例子中,我们将使用Pandas方法agg、groupby和reset_index,以及Pyjanitor方法collapse_levels来计算每个扇区的平均值和标准:

c419f22425e61dd468c05e8938e308cb.png

更多关于使用Python和Pandas对数据进行分组和聚合的文章:

  • Python Pandas分组教程 https://www.marsja.se/python-pandas-groupby-tutorial-examples/
  • 使用Python进行描述性统计 https://www.marsja.se/pandas-python-descriptive-statistics/

结论

在这篇文章中,我们学习了一些数据清理方法。具体来说,我们学习了如何向一个Pandas数据帧追加一个列、删除空列、处理缺失值以及重命名列(即,获得更好的列名)。当然,当我们使用Pandas和Pyjanitor时,还有更多的数据清理方法可用。

总之,此Python包所增加的方法与R包janitor和dplyr中的方法是相似的。在预处理数据时,这些方法将使我们的生活更容易。

看完大家可以试一试啦,如果对您有帮助请转发并关注小编,您的支持是对我们最大的鼓励!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值