我有一个数据框
import pandas as pd
import numpy as np
df1=pd.DataFrame({'group':[1,1,2,2,2],
'value':[2,3,np.nan,5,4]})
df1
group value
0 1 2
1 1 3
2 2 NaN
3 2 5
4 2 4
我想在
value
的值为NaN
的每个组之后添加一行。期望输出为: group value
0 1 2
1 1 3
2 1 NaN
3 2 NaN
4 2 5
5 2 4
6 2 NaN
在我的真实数据集中,除了
value
之外,我还有很多组和更多列,我希望所有这些行都在新添加的行中成为NaN
。非常感谢您的帮助
最佳答案
带concat
的append
s = df1.groupby('group')
out = pd.concat([i.append({'value': np.nan}, ignore_index=True) for _, i in s])
out.group = out.group.ffill().astype(int)
带有
apply
的append
[1]df1.groupby('group').apply(
lambda d: d.append({'group': d.name}, ignore_index=True).astype({'group': int})
).reset_index(drop=True)
两者都会产生:
group value
0 1 2.0
1 1 3.0
2 1 NaN
3 2 NaN
4 2 5.0
5 2 4.0
6 2 NaN
[1]您本地的@piRSquared为您带来的解决方案
关于python - Pandas -在 Pandas 中为每个组插入空白行,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/51884792/