python qcut_Python中pandas的qcut函数的用法

本文介绍了pandas的qcut函数,用于将数据基于分位数进行等长分箱。通过示例展示了如何将正态分布的1000个数据点均匀分为四份,并如何自定义分位数进行分箱,从而理解qcut的工作原理。
摘要由CSDN通过智能技术生成

在《利用Python进行数据分析》这本书的第七章介绍了pandas的qcut函数的用法。原书介绍qcut函数是一个与分箱密切相关的函数,它基于样本分位数进行分箱,可以通过qcut获得等长的箱:

data = np.random.randn(1000)#data服从正态分布

cats = pd.qcut(data, 4)#将data均匀分成四份

cats

Out: [(0.657, 3.349], (-0.722, -0.0358], (-3.016, -0.722], (-3.016, -0.722], (-3.016, -0.722], ..., (-0.722, -0.0358], (-0.722, -0.0358], (-0.722, -0.0358], (-0.0358, 0.657], (-0.0358, 0.657]]

Length: 1000

Categories (4, interval[float64]): [(-3.016, -0.722] < (-0.722, -0.0358] < (-0.0358, 0.657] < (0.657, 3.349]]

pd.value_counts(cats)#使用qcut获得了等长的箱

Out: (0.657, 3.349] 250

(-0.0358, 0.657] 250

(-0.722, -0.0358] 250

(-3.016, -0.722] 250

dtype: int64

data里面的元素服从正态分布,长度为1000,qcut将data按照每250的数据量将data分箱,分出4个等长的箱

我们也可以传入自定义的分位数(0和1之间的数据)

pd.qcut(data, [0, 0.1, 0.5, 0.9, 1.])

Out: [(1

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值