删除放置在匹配条件行之前的行

2024-04-20 00:58:11 发布

您现在位置:Python中文网/ 问答频道 /正文

您能建议我如何删除特定条件之前的行吗。 例如,如何删除条件行(Delta<;10)前一行的“f”行

 A   B  DateTime           Direction    Nom   Delta 
a  6.5  1  2017-06-01 15:37     B          10    Na
b  6.8  0  
c  7    0  
f  6    1  16:21                S           6    25   
h  6.1  1  16:28                S           15   7  
i  6.2  0  
j  

Tags: ltdatetime条件nom建议deltanadirection
1条回答
网友
1楼 · 发布于 2024-04-20 00:58:11

您需要比较列和移位掩码,最后按^{}筛选:

df = df[~df['Delta'].lt(10).shift(-1).fillna(False)]
print (df)
     A    B          DateTime Direction   Nom  Delta
a  6.5  1.0  2017-06-01 15:37         B  10.0    NaN
b  6.8  0.0               NaN       NaN   NaN    NaN
c  7.0  0.0               NaN       NaN   NaN    NaN
h  6.1  1.0             16:28         S  15.0    7.0
i  6.2  0.0               NaN       NaN   NaN    NaN
j  NaN  NaN               NaN       NaN   NaN    NaN

相关问题 更多 >