繁体   English   中英

如何根据另一列的值范围过滤列?

[英]How to filter column based on range of values from another column?

我有一个如下所示的 df,其中 y 是目标(0 或 1)。 如何根据我的 x 的值范围找到 y 的百分比为 0 或 1?

示例:对于介于 0 和 20 之间的 x 值,相应的 y 为 10% 1(和 90% 0)。

在此处输入图像描述

首先我们可以使用pd.cut ,然后是crosstab

out = pd.crosstab(pd.cut(df['x'], [0,20,....]),df['y'], normalize='index')

我希望你喜欢单线。 假设a是您的 dataframe:

a.loc[(a.x < 20) & (a.x > 0),'y'].value_counts(normalize=True).to_frame('frequency')

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM