gpt4 book ai didi

python - 在 Python 中删除包含 NaN 的行前后的行?

转载 作者:太空狗 更新时间:2023-10-30 00:58:16 25 4
gpt4 key购买 nike

我正在尝试使用带有 numpy 和 pandas 的 python 清理实验数据。我的一些测量结果令人难以置信。我想从同一样本中删除这些测量值以及前面的 2 个和后面的 2 个测量值。由于我的数据帧非常大,我正在尝试找到一种无需使用 for 循环即可实现此目的的优雅方法。

我的数据:

>>>df

Date Time Sample Measurement
index
7737 2019-04-15 06:40:00 A 6.560
7739 2019-04-15 06:50:00 A 1.063
7740 2019-04-15 06:55:00 A 1.136
7741 2019-04-15 07:00:00 A 1.301
7742 2019-04-15 07:05:00 A 1.435
7743 2019-04-15 07:10:00 A 1.704
7744 2019-04-15 07:15:00 A 1.961
7745 2019-04-15 07:20:00 A 2.023
7746 2019-04-15 07:25:00 A 6.284
7747 2019-04-15 07:30:00 A 2.253
7748 2019-04-15 07:35:00 A 6.549
7749 2019-04-15 07:40:00 A 2.591
7750 2019-04-15 07:45:00 A 6.321
7752 2019-04-15 07:55:00 A 0.937
7753 2019-04-15 08:00:00 B 0.372
7754 2019-04-15 08:05:00 B 0.382
7755 2019-04-15 08:10:00 B 0.390
7756 2019-04-15 08:15:00 B 0.455
7757 2019-04-15 08:20:00 B 6.499


import numpy as np
import pandas as pd

df['Measurement'] = np.where(df['Measurement']>6.0, np.nan, df['Measurement'])

给予

>>>df

Date Time Sample Measurement
index
7737 2019-04-15 06:40:00 A NaN
7739 2019-04-15 06:50:00 A 1.063
7740 2019-04-15 06:55:00 A 1.136
7741 2019-04-15 07:00:00 A 1.301
7742 2019-04-15 07:05:00 A 1.435
7743 2019-04-15 07:10:00 A 1.704
7744 2019-04-15 07:15:00 A 1.961
7745 2019-04-15 07:20:00 A 2.023
7746 2019-04-15 07:25:00 A NaN
7747 2019-04-15 07:30:00 A 2.253
7748 2019-04-15 07:35:00 A NaN
7749 2019-04-15 07:40:00 A 2.591
7750 2019-04-15 07:45:00 A NaN
7752 2019-04-15 07:55:00 A 0.937
7753 2019-04-15 08:00:00 B 0.372
7754 2019-04-15 08:05:00 B 0.382
7755 2019-04-15 08:10:00 B 0.390
7756 2019-04-15 08:15:00 B 0.455
7757 2019-04-15 08:20:00 B NaN

我使用

删除了行
df= df[np.isfinite(df['Measurement'])]

在删除样本中包含 NaN 的行之前和之后的 2 行后,我试图获得的结果(请注意,必须保留 7753,因为此测量值属于样本 B)。


Date Time Sample Measurement
index
7741 2019-04-15 07:00:00 A 1.301
7742 2019-04-15 07:05:00 A 1.435
7743 2019-04-15 07:10:00 A 1.704
7753 2019-04-15 08:00:00 B 0.372
7754 2019-04-15 08:05:00 B 0.382


最佳答案

我们可以标记所有NaN前后两处的索引,然后将它们的值也替换为NaN:

# Get indices of NaN's
idxnull = df[df['Measurement'].isnull()].index

a = [range(x+2) if x==0 else range(x-2, x) if x==idxnull.max() else range(x-2, x+2) for x in idxnull]

for rng in a:
df.loc[rng, 'Measurement'] = np.NaN

df.dropna(inplace=True)
df = df.iloc[1:]

    Index        Date      Time Sample  Measurement
3 7741 2019-04-15 07:00:00 A 1.301
4 7742 2019-04-15 07:05:00 A 1.435
5 7743 2019-04-15 07:10:00 A 1.704
14 7753 2019-04-15 08:00:00 B 0.372
15 7754 2019-04-15 08:05:00 B 0.382

列表理解看起来很困难,但它如下:

for x in idxnull:
if x > 0:
range(x-2, x+2)
elif x==idxnull.max():
range(x-2)
else:
range(x+2)

关于python - 在 Python 中删除包含 NaN 的行前后的行?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56292555/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com