Pandas 数据框中的随机行选择

2025-03-13 09:19:00
admin
原创
13
摘要:问题描述:有没有办法从 Pandas 中的 DataFrame 中选择随机行。在 R 中,使用 car 包,有一个有用的函数some(x, n),它类似于 head,但在此示例中,从 x 中随机选择 10 行。我也查看了切片文档,似乎没有相同的东西。更新现在使用版本20。有一个示例方法。df.sample(n...

问题描述:

有没有办法从 Pandas 中的 DataFrame 中选择随机行。

在 R 中,使用 car 包,有一个有用的函数some(x, n),它类似于 head,但在此示例中,从 x 中随机选择 10 行。

我也查看了切片文档,似乎没有相同的东西。

更新

现在使用版本20。有一个示例方法。

df.sample(n)

解决方案 1:

在 pandas 版本0.16.1及更高版本中,现在有一个DataFrame.sample 内置方法:

import pandas

df = pandas.DataFrame(pandas.np.random.random(100))

# Randomly sample 70% of your dataframe
df_percent = df.sample(frac=0.7)

# Randomly sample 7 elements from your dataframe
df_elements = df.sample(n=7)

对于上述任何一种方法,您都可以通过执行以下操作来获取其余的行:

df_rest = df.loc[~df.index.isin(df_percent.index)]

根据Pedram评论,如果您想获得可重现的样本,请传递random_state参数。

df_percent = df.sample(frac=0.7, random_state=42)

解决方案 2:

像这样吗?

import random

def some(x, n):
    return x.ix[random.sample(x.index, n)]

注意:从 Pandas v0.20.0 开始,ix 已弃用基于loc标签的索引。

解决方案 3:

sample

从 v0.20.0 开始,您可以使用pd.DataFrame.sample,它可用于返回固定数量行或一定百分比行的随机样本:

df = df.sample(n=k)     # k rows
df = df.sample(frac=k)  # int(len(df.index) * k) rows

为了可重复性,您可以指定一个整数random_state,相当于使用np.ramdom.seed。因此,例如,np.random.seed = 0您可以设置,而不是:

df = df.sample(n=k, random_state=0)

解决方案 4:

最好的方法是使用随机模块中的样本函数,

import numpy as np
import pandas as pd
from random import sample

# given data frame df

# create random index
rindex =  np.array(sample(xrange(len(df)), 10))

# get 10 random rows from df
dfr = df.ix[rindex]

解决方案 5:

下面的行将从数据框 df 中的现有总行数中随机选择 n 行,无需替换。

df = df.take(np.random.permutation(len(df))[:n])

解决方案 6:

实际上,这将为您提供重复的索引,np.random.random_integers(0, len(df), N)其中N的数字很大。

相关推荐
  政府信创国产化的10大政策解读一、信创国产化的背景与意义信创国产化,即信息技术应用创新国产化,是当前中国信息技术领域的一个重要发展方向。其核心在于通过自主研发和创新,实现信息技术应用的自主可控,减少对外部技术的依赖,并规避潜在的技术制裁和风险。随着全球信息技术竞争的加剧,以及某些国家对中国在科技领域的打压,信创国产化显...
工程项目管理   1590  
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   1361  
  信创产品在政府采购中的占比分析随着信息技术的飞速发展以及国家对信息安全重视程度的不断提高,信创产业应运而生并迅速崛起。信创,即信息技术应用创新,旨在实现信息技术领域的自主可控,减少对国外技术的依赖,保障国家信息安全。政府采购作为推动信创产业发展的重要力量,其对信创产品的采购占比情况备受关注。这不仅关系到信创产业的发展前...
信创和国产化的区别   18  
  信创,即信息技术应用创新产业,旨在实现信息技术领域的自主可控,摆脱对国外技术的依赖。近年来,国货国用信创发展势头迅猛,在诸多领域取得了显著成果。这一发展趋势对科技创新产生了深远的推动作用,不仅提升了我国在信息技术领域的自主创新能力,还为经济社会的数字化转型提供了坚实支撑。信创推动核心技术突破信创产业的发展促使企业和科研...
信创工作   18  
  信创技术,即信息技术应用创新产业,旨在实现信息技术领域的自主可控与安全可靠。近年来,信创技术发展迅猛,对中小企业产生了深远的影响,带来了诸多不可忽视的价值。在数字化转型的浪潮中,中小企业面临着激烈的市场竞争和复杂多变的环境,信创技术的出现为它们提供了新的发展机遇和支撑。信创技术对中小企业的影响技术架构变革信创技术促使中...
信创国产化   19  
热门文章
项目管理软件有哪些?
云禅道AD
禅道项目管理软件

云端的项目管理软件

尊享禅道项目软件收费版功能

无需维护,随时随地协同办公

内置subversion和git源码管理

每天备份,随时转为私有部署

免费试用