如果我有一个数据框,例如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?
来做到这一点答案 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