【问题标题】:Assigning percentile to each value of pandas series为熊猫系列的每个值分配百分位数
【发布时间】:2020-08-19 10:12:10
【问题描述】:

是否有直接开箱即用的方式为 pandas 系列的每个值分配百分位数?

我正在通过排名和重新缩放来实现此计算,如下所示:

values = pd.Series(np.random.normal(0,1,100))
percentiles = values.rank()/values.shape

例如系列:[0,2,4,2,10,8,6,1]

应该收到百分位数:[0.125, 0.4375, 0.625, 0.4375, 1.0, 0.875, 0.75, 0.25]

但是我很惊讶没有针对此的本地解决方案(例如 qcutquantile 等...)

有明确的计算方法吗?

【问题讨论】:

    标签: python pandas series percentile


    【解决方案1】:

    您可以使用rank 执行此操作,其中pct=True 选项以percentile 形式显示排名。

    In [1551]: v = pd.Series([0,2,4,2,10,8,6,1])
    In [1556]: v.rank(pct=True)                 
    Out[1556]: 
    0    0.1250
    1    0.4375
    2    0.6250
    3    0.4375
    4    1.0000
    5    0.8750
    6    0.7500
    7    0.2500
    dtype: float64
    

    【讨论】:

      猜你喜欢
      • 2022-01-24
      • 2017-03-05
      • 2021-08-17
      • 2022-01-16
      • 2017-05-13
      • 2014-04-15
      • 2022-11-29
      • 2022-11-17
      • 1970-01-01
      相关资源
      最近更新 更多