从数据框中随机选择数据但不重复

时间:2015-03-18 21:45:02

标签: python r random pandas

如果我有一个数据框,例如1到50之间的数字,那么我需要'X'个数字集,每个集包含'Y'随机数。这个数字不能重复。

例如,X =5 and Y=5

X1 1, 8, 12, 17, 16
X2 9, 22, 45, 47, 23
X3 13, 19, 21, 34, 50
X4 46, 49, 29, 38, 11 
X5 33, 26, 14, 7, 6

有谁知道我怎么能通过python Pandas或随机包或R?

来做到这一点

1 个答案:

答案 0 :(得分:1)

In [64]:

np.random.choice(np.arange(1,51), (5,5), replace=False)
Out[64]:
array([[18, 35, 20, 39,  7],
       [27, 41, 26, 30, 14],
       [47, 23, 17, 40, 38],
       [34,  6,  3, 42, 31],
       [48, 49, 16, 15,  1]])

然后您可以将其传递给df构造函数:

In [65]:

pd.DataFrame(np.random.choice(np.arange(1,51), (5,5), replace=False))
Out[65]:
    0   1   2   3   4
0  35  41  38  50  26
1  24  34  14   2  29
2   8  43  25  17  49
3  30   5  40   6  21
4  20  11  31  33  23