Python Pandas数据清洗之缺失数据处理

ops/2024/9/23 5:46:46/

大家好,在数据分析和处理过程中,缺失数据是常见且不可避免的现象。无论是在数据收集、传输或存储的过程中,数据集可能会出现部分丢失。缺失数据的存在不仅会影响数据的完整性,还可能对后续的数据分析和建模造成不利影响。为了保证数据质量,合理处理缺失数据至关重要。

Python的Pandas库提供了强大的工具,能够高效处理数据中的缺失值,特别是通过插值和填充技术来弥补数据的缺失。本文将介绍如何使用Pandas处理数据中的缺失值,着重探讨插值和填充的技巧。通过这些方法,可以保证数据集的完整性,并提高分析结果的准确性。

1.缺失数据的检测

在Pandas中,缺失数据通常用 NaN(Not a Number)表示。Pandas提供了多种方法来检测数据中的缺失值。常见的检测方法包括 isna()isnull(),这两个方法可以检测数据中的 NaN 值,并返回一个布尔值数据框。

python">import pandas as pd
import numpy as np# 创建一个包含缺失数据的DataFrame
data = {'A': [1, 2, np.nan, 4, 5],'B': [10, np.nan, np.nan, 40, 50],'C': [100, 200, 300, np.nan, 500]
}df = pd.DataFrame(data)# 检测缺失值
print(df.isna())

输出结果:

python">       A      B      C
0  False  False  False
1  False   True  False
2   True   True  False
3  False  False   True
4  False  False  False

isna() 返回了一个布尔值数据框,标识出哪些位置有缺失值。True 表示对应位置的值为 NaNFalse 表示该位置的数据是完整的。

2.删除缺失数据

在某些情况下,删除包含缺失值的行或列是处理缺失数据的一个简单有效的方法。Pandas提供了 dropna() 方法来删除缺失值。根据需要,可以删除整行或整列。

python"># 删除包含缺失值的行
df_dropna_rows = df.dropna()
print(df_dropna_rows)# 删除包含缺失值的列
df_dropna_columns = df.dropna(axis=1)
print(df_dropna_columns)

删除包含缺失值的行:

python">     A     B      C
0  1.0  10.0  100.0
4  5.0  50.0  500.0

删除包含缺失值的列:

python">     A
0  1.0
1  2.0
2  NaN
3  4.0
4  5.0

dropna()axis 参数控制删除行还是列,axis=0 表示删除行,axis=1 表示删除列。

尽管删除缺失数据是一种简单的方法,但在某些情况下,删除数据可能导致信息丢失过多。因此,更合理的选择是使用插值和填充技术来补全缺失值。

3.使用填充技术处理缺失数据

Pandas提供了 fillna() 方法来填充缺失数据,常见的填充策略包括使用固定值填充、前向填充(ffill)和后向填充(bfill)。

3.1 使用固定值填充

# 使用固定值0填充缺失值
df_fillna_0 = df.fillna(0)
print(df_fillna_0)

输出结果:

python">     A     B      C
0  1.0  10.0  100.0
1  2.0   0.0  200.0
2  0.0   0.0  300.0
3  4.0  40.0    0.0
4  5.0  50.0  500.0

在这个示例中,fillna(0) 将所有的 NaN 值替换为0。

3.2 前向填充(ffill)

前向填充是指用前一个有效数据填充缺失值,常用于时间序列数据。

python"># 使用前向填充
df_ffill = df.fillna(method='ffill')
print(df_ffill)

输出结果:

python">     A     B      C
0  1.0  10.0  100.0
1  2.0  10.0  200.0
2  2.0  10.0  300.0
3  4.0  40.0  300.0
4  5.0  50.0  500.0

3.3 后向填充(bfill)

后向填充则是用后一个有效数据填充缺失值。

python"># 使用后向填充
df_bfill = df.fillna(method='bfill')
print(df_bfill)

输出结果:

python">     A     B      C
0  1.0  10.0  100.0
1  2.0  40.0  200.0
2  4.0  40.0  300.0
3  4.0  40.0  500.0
4  5.0  50.0  500.0

前向填充和后向填充对于时间序列数据尤其有效,可以根据实际业务逻辑选择合适的填充方向。

4.使用插值技术处理缺失数据

插值是一种根据已有数据来估计缺失值的技术。Pandas提供了 interpolate() 方法,可以根据多种插值方式填充缺失值。常见的插值方法包括线性插值、时间插值等。

4.1 线性插值

线性插值是最常用的插值方法,它通过现有的两个数据点之间的线性关系来填补中间的缺失值。

python"># 使用线性插值填充缺失值
df_interpolate = df.interpolate()
print(df_interpolate)

输出结果:

python">     A     B      C
0  1.0  10.0  100.0
1  2.0  25.0  200.0
2  3.0  32.5  300.0
3  4.0  40.0  400.0
4  5.0  50.0  500.0

在这个示例中,interpolate() 方法使用线性插值填补了 NaN 值,使得数据更加平滑和连续。

4.2 时间插值

时间插值对于处理时间序列数据非常有用,它基于时间轴对数据进行插值。

python"># 创建一个包含时间序列数据的DataFrame
time_data = {'日期': pd.date_range('2024-01-01', periods=5),'数值': [np.nan, 2, np.nan, 8, 10]
}df_time = pd.DataFrame(time_data)
df_time.set_index('日期', inplace=True)# 使用时间插值填充缺失值
df_time_interpolated = df_time.interpolate(method='time')
print(df_time_interpolated)

输出结果:

python">            数值
日期             
2024-01-01  2.0
2024-01-02  2.0
2024-01-03  5.0
2024-01-04  8.0
2024-01-05  10.0

在时间序列数据中,使用时间插值可以根据日期自动推算缺失值,填补后的数据保持了时间上的连续性。

4.3 多种插值方法

Pandas的 interpolate() 方法支持多种插值方法,包括 polynomial(多项式插值)、spline(样条插值)等。可以根据数据特性选择适合的插值方法。

python"># 使用多项式插值
df_poly_interpolate = df.interpolate(method='polynomial', order=2)
print(df_poly_interpolate)

在这个示例中,使用二次多项式插值填补了缺失值,多项式插值适合处理有曲线趋势的数据。

在数据分析中,缺失数据的处理是至关重要的一步,直接影响到分析结果的准确性。Python的Pandas库提供了多种有效的工具和方法来处理缺失数据,尤其是通过插值和填充技术。通过合理选择这些数据清洗方法,可以有效地弥补数据集中存在的空白,保证数据的连续性和完整性。


http://www.ppmy.cn/ops/114604.html

相关文章

JS实现数组去重常见方法

写在前面 今天在实现数组去重时&#xff0c;使用了多种方法实现。在此总结一下数组去重常见方法。 01_多重for循环去重 let arr [1, 2, 2, 3, 3, 1, 2] // 多层for循环去重 for (let i 0;i < arr.length;i) {for (let j i 1;j < arr.length;j) {if (arr[i] …

给子组件传递dom元素引用实例方案

在实际开发中有一个比较常见的场景是&#xff0c;父组件写了一个el-form组件。然后里面内容很多&#xff0c;所以拆成了子组件。那么子组件中就有调用父组件的form实例方法的需求。到所以这就涉及一个问题&#xff0c;怎么把父组件的form实例传递给子应用。 这里传递后直接调用…

【Azure Redis 缓存】Azure Redis出现了超时问题后,记录一步一步的排查出异常的客户端连接和所执行命令的步骤

问题描述 Azure Redis在使用的过程中&#xff0c;多次无规律的出现超时问题。抓取到客户端的异常错误后&#xff0c;想进一步的分析是何原因导致了如下异常呢&#xff1f; Timeout awaiting response (outbound0KiB, inbound0KiB, 5984ms elapsed, timeout is 5000ms), command…

pg入门15—pg中fts configurations是什么

在 PostgreSQL 中&#xff0c;FTS configurations&#xff08;全文搜索配置&#xff09;是用于定义文本分析和搜索行为的设置。这些配置决定了如何处理和解析输入文本&#xff0c;以便进行高效的全文搜索。 主要组成部分 词汇表&#xff1a; 确定哪些词会被视为搜索词&#xf…

【mac】MacOS无法打开XXX文件,因为无法验证开发者的问题解决

博主介绍&#xff1a; 大家好&#xff0c;我是想成为Super的Yuperman&#xff0c;互联网宇宙厂经验&#xff0c;17年医疗健康行业的码拉松奔跑者&#xff0c;曾担任技术专家、架构师、研发总监负责和主导多个应用架构。 技术范围&#xff1a; 目前专注java体系&#xff0c;以及…

Maven国内镜像(四种)

配置Maven使用国内镜像是一个常见的做法&#xff0c;因为这样可以显著提高依赖下载的速度并避免网络不稳定带来的问题 在 settings.xml 文件中&#xff0c;需要添加或修改 <mirrors> 标签来指定国内镜像。 以下是几个可用的镜像 1. 阿里云 <mirrors> <mi…

学习整理vue前端框架项目目录结构的含义

学习整理vue前端框架项目目录结构的含义 1、目录结构2、结构含义 1、目录结构 2、结构含义

git merge如何忽略部分路径

参考文章&#xff1a; Git - Ignore files during merge How to make git ignore a directory while merging 在进行git merge时&#xff0c;想忽略部分路径的回合。 如&#xff1a;将develop分支merge回master&#xff0c;但是忽略/path/to/folder路径 操作&#xff1a; gi…