基于字符串的列条件填充

2024-05-18 08:44:07 发布

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

我有一个数据集,我必须填充条件行或删除条件行。但是,我还是不成功

Idx Fruits Days Name
0 60 20 
1 15 85.5
2 10 62 Peter
3 40 90 Maria
4 5 10.2
5 92 66
6 65 87 John
7 50 1 Eric
8 50 0 Maria
9 80 87 John

现在,我有一些空牢房。我可以用fillna或regex填充,也可以删除空单元格。 在字符串开始之前,我只需要第一个开始的单元格,可以删除,也可以用"."填充

如下

Idx Fruits Days Name
0 60 20 .
1 15 85.5 .
2 10 62 Peter
3 40 90 Maria
4 5 10.2
5 92 66
6 65 87 John
7 50 1 Eric
8 50 0 Maria
9 80 87 John

Idx Fruits Days Name
2 10 62 Peter
3 40 90 Maria
4 5 10.2
5 92 66
6 65 87 John
7 50 1 Eric
8 50 0 Maria
9 80 87 John

有没有可能使用熊猫?或任何循环


Tags: 数据字符串name条件johndaysregexpeter
1条回答
网友
1楼 · 发布于 2024-05-18 08:44:07

您可以尝试以下方法:

df['Name'] = df['Name'].replace('', np.nan)
df['Name'] = df['Name'].where(df['Name'].ffill().notna(), '.')
print(df)

   Idx  Fruits  Days   Name
0    0      60  20.0      .
1    1      15  85.5      .
2    2      10  62.0  Peter
3    3      40  90.0  Maria
4    4       5  10.2   
5    5      92  66.0   
6    6      65  87.0   John
7    7      50   1.0   Eric
8    8      50   0.0  Maria
9    9      80  87.0   John

相关问题 更多 >