pandas pd.cut()与pd.qcut()

本文详细介绍Pandas库中pd.cut和pd.qcut函数的使用方法,包括参数解析及代码示例,展示如何对一维数据进行等距或按频率划分。

 

1、pd.cut函数有7个参数,主要用于对数据从最大值到最小值进行等距划分

 pandas.cut(x, bins, right=True, labels=None, retbins=False, precision=3, include_lowest=False)

参数:

x : 输入待cut的一维数组

bins : cut的段数,一般为整型,但也可以为序列向量。

right : 布尔值,确定右区间是否开闭,取True时右区间闭合

labels : 数组或布尔值,默认为None,用来标识分后的bins,长度必须与结果bins相等,返回值为整数或者对bins的标识

retbins : 布尔值,可选。是否返回数值所在分组,Ture则返回

precision : 整型,bins小数精度,也就是数据以几位小数显示

include_lowest : 布尔类型,是否包含左区间

2、pd.qcut函数,按照数据出现频率百分比划分,比如要把数据分为四份,则四段分别是数据的0-25%,25%-50%,50%-75%,75%-100%

pd.qcut(x, q, labels=None, retbins=False, precision=3, duplicates='raise')

代码示例:

import numpy as np
from numpy import *
import pandas as pd
df = pd.DataFrame()
df['data'] = [1,2,2,2,2,6,7,8,9,0]#这里注意箱边界值需要唯一,不然qcut时程序会报错
df['cut']=pd.cut(df['data'],5)
df['qcut']=pd.qcut(df['data'],5)
df.head(10)

运行结果如图:

可以看到cut列各个分段之间间距相等,qcut由于数据中‘2’较多,所以2附近间距较小,2之后的分段间距较大。 

 

### 概念重述 您提到的 `pd.cut` 和 `pd.qcut` 是 Pandas 中用于**离散化连续数据**的两个函数。它们可以将连续型变量划分到不同的“面元”或“区间”中,适用于分类统计、数据预处理等场景。 --- ### 详解 #### 1. `pd.cut(x, bins, ...)` - **作用**:将连续变量 `x` 按照指定的 `bins`(边界)进行**等宽划分**。 - **适用于**:你已经知道划分的边界,或希望按照固定宽度进行离散化。 - **参数说明**: - `x`:要离散化的数组或 Series。 - `bins`:可以是整数(表示划分成多少个等宽区间),也可以是一个列表或数组,指定每个区间的上下界。 - **示例**: ```python import pandas as pd ages = [18, 25, 35, 45, 55, 65] bins = [18, 30, 40, 50, 60, 70] pd.cut(ages, bins) ``` 输出: ``` [(18, 30], (18, 30], (30, 40], (40, 50], (50, 60], (60, 70]] ``` #### 2. `pd.qcut(x, q, ...)` - **作用**:将连续变量 `x` 按照**分位数**进行**等频划分**。 - **适用于**:希望每个区间中包含的样本数量大致相等。 - **参数说明**: - `x`:要离散化的数组或 Series。 - `q`:可以是整数(表示分成 `q` 个等频区间),也可以是一个表示分位点的列表(如 `[0, 0.25, 0.5, 0.75, 1]`)。 - **示例**: ```python data = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] pd.qcut(data, q=4) ``` 输出: ``` [(-0.001, 3.25], (-0.001, 3.25], (-0.001, 3.25], (3.25, 5.5], (3.25, 5.5], (5.5, 7.75], (5.5, 7.75], (7.75, 10.0], (7.75, 10.0], (7.75, 10.0]] ``` --- ### 知识点 1. **pd.cut 等宽离散化** 按指定区间划分数据,适用于分布已知或需固定区间的情况。 2. **pd.qcut 等频离散化** 按分位数划分数据,确保每个区间样本数大致相等,适用于数据分布不均的情况。 3. **数据分箱离散化** 将连续特征转换为分类特征,有助于提升模型的解释性和鲁棒性。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值