0
我有陣列的列表在Python隨機分裂陣列的列表在Python
import numpy as np
mylist = [np.random.randint(0, i, int(10)) for i in (10,100,3)]
[array([5, 5, 7, 2, 0, 5, 7, 8, 6, 9]), array([42, 70, 30, 62, 44, 8, 40, 68, 46, 93]), array([0, 0, 0, 0, 0, 1, 2, 0, 1, 2])]
我希望分裂(如果可能隨機地)例如在兩個列表
list_one = [array([5, 5, 7, 2, 0]), array([42, 70, 30, 62, 44]), array([0, 0, 0, 0, 0])]
list_two = [array([5, 7, 8, 6, 9]), array([8, 40, 68, 46, 93]), array([1, 2, 0, 1, 2])]
或50% 30%和70%
list_one = [array([5, 5, 7]), array([42, 70, 30]), array([0, 0, 0])]
list_two = [array([2, 0, 5, 7, 8, 6, 9]), array([62, 44, 8, 40, 68, 46, 93]), array([0, 0, 1, 2, 0, 1, 2])]
因此,例如,你想隨機選擇元素的所有元素的50%,並把它們放在一個列表,其餘在另一份清單去?這很簡單但很乏味。首先使用chain.from_iterable展開列表,然後爲每個元素運行random.uniform(0,1),如果結果小於.5,則將其放入第一個列表中,否則將其放入第二個列表中。對於30:70分割,使條件小於.3的第一個列表。對於較難預測的結果,請使用random.SystemRandom()。random()。 – 2015-09-05 04:57:23
你想隨機選擇一個分割點(也就是將一個數組「剪切」爲兩個),還是隨機選取元素(如Tris Nefzger的評論中所述)?必須在結果列表中數組的大小是否相同(即,list_one的所有元素都必須是相同的長度)? –
嘿傢伙,謝謝。如果這不是太困難,我希望或減少(如果更容易,因爲它們已經是隨機數)了。我正在嘗試尋找一種優雅的方式來解決這個乏味的問題 –