python - Pandas groupby : percentage above threshold

标签 python pandas

我有一个 DataFrame,我希望在其上使用 groupby,但我正在寻找一些不寻常的函数来进行聚合。我想让每个组中的观察百分比超过某个阈值。例如,阈值为 0 时,DataFrame

df = pd.DataFrame(dict(day=[1, 1, 1, 2, 2, 2, 3, 3, 3, 4], value=[0, 4, 0, 4, 0, 4, 0, 4, 0, 4]))

df
   day  value
0    1      0
1    1      4
2    1      0
3    2      4
4    2      0
5    2      4
6    3      0
7    3      4
8    3      0
9    4      4

应该变成

df_group = pd.DataFrame(dict(day=[1, 2, 3, 4], value=[.33, .67, .33, 1.0]))

df_group
   day  value
0    1   0.33
1    2   0.67
2    3   0.33
3    4   1.00

我还在处理一个相当大的数据集,所以我希望能将计算时间考虑在内。

最佳答案

>>> df.groupby('day')['value'].apply(lambda c: (c>0).sum()/len(c))
day
1      0.333333
2      0.666667
3      0.333333
4      1.000000
Name: value, dtype: float64

关于python - Pandas groupby : percentage above threshold,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28683498/

相关文章:

python - 数据帧到 np.array - IndexError : tuple index out of range

python - 在提取子集时如何保留 NAN 值?

Python Pandas 迭代列并根据应用条件更新列

python - 如何根据另一列的值在 Pandas 数据框列中创建新值

python - 如果使用OpenCV的HoughCircles,是否有推荐的方法来确定minRadius以便在图像中找到1个圆?

python - 如何在条件语句中使用 random.choices 变量

python - 如何解释线性判别分析中的变量权重?

python - Django开发服务器的容量

python - 如何使用 python 和 pandas 导入 Excel 文件并搜索特定记录?

python - 如何对不同的迭代值求和?