在Pandas中有方法从数据帧中随机选择行吗?
在R中,使用car包,有一个有用的函数some(x, n),它类似于head,但在本例中,从x中随机选择10行。
我也看了切片文档,似乎没有什么等价的。
更新
现在使用版本20。这里有一个示例方法。
df.sample(n)
在Pandas中有方法从数据帧中随机选择行吗?
在R中,使用car包,有一个有用的函数some(x, n),它类似于head,但在本例中,从x中随机选择10行。
我也看了切片文档,似乎没有什么等价的。
更新
现在使用版本20。这里有一个示例方法。
df.sample(n)
当前回答
下面的行将从数据帧df中随机选择n个现有的行号,而不进行替换。
df = df.take(np.random.permutation(len(df))[:n])
其他回答
最好的方法是用随机模块中的样本函数,
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]
实际上这会给你一个重复的np。random指标。random_integers(0, len(df), N),其中N是一个大数字。
像这样的东西?
import random
def some(x, n):
return x.ix[random.sample(x.index, n)]
注意:从Pandas v0.20.0开始,已弃用ix,改用loc进行基于标签的索引。
下面的行将从数据帧df中随机选择n个现有的行号,而不进行替换。
df = df.take(np.random.permutation(len(df))[:n])
样本
从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)