pandas 分层抽样

分层抽样(Stratified Sampling)是一种统计学中的抽样方法,它根据数据的不同特征将总体划分为若干个互不相交的子集(层),然后从每个子集中随机抽取样本,在pandas中,我们可以使用sample函数进行分层抽样。

pandas 分层抽样
(图片来源网络,侵删)

以下是使用pandas进行分层抽样的详细步骤:

1、导入pandas库

import pandas as pd

2、创建一个数据集

data = {'A': ['foo', 'bar', 'baz', 'foo', 'bar', 'baz'],
        'B': ['one', 'two', 'three', 'two', 'three', 'one'],
        'C': [1, 2, 3, 4, 5, 6],
        'D': [10, 20, 30, 40, 50, 60]}
df = pd.DataFrame(data)

3、根据某个或多个列对数据集进行分层

strata = df[['A', 'B']]  # 根据列'A'和'B'进行分层

4、设置抽样比例和抽样数量

sample_ratio = 0.5  # 抽样比例为50%
sample_size = int(len(df) * sample_ratio)  # 计算抽样数量

5、使用sample函数进行分层抽样

sampled_df = df.groupby(strata).apply(lambda x: x.sample(n=sample_size)).reset_index(drop=True)

6、查看抽样结果

print(sampled_df)

通过以上步骤,我们可以在pandas中实现分层抽样,需要注意的是,分层抽样要求数据集中的每一行都有一个唯一的标识,以便我们可以根据这些标识将数据划分为不同的层。

原创文章,作者:未希,如若转载,请注明出处:https://www.kdun.com/ask/474039.html

(0)
未希新媒体运营
上一篇 2024-04-14 17:33
下一篇 2024-04-14 17:34

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注

云产品限时秒杀。精选云产品高防服务器,20M大带宽限量抢购  >>点击进入