可能重复:
splitting a list of arbitrary size into only roughly N-equal parts
How do you split a list into evenly sized chunks in Python?
我需要创建一个将列表拆分为列表列表的函数,每个列表包含相同数量的项目(或尽可能相等)。
e.g。
def split_lists(mainlist, splitcount):
....
mylist = [1,2,3,4,5,6]
split_list(mylist,2)
将返回两个包含三个元素的列表的列表 - [[1,2,3][4,5,6]]
。
split_list(mylist,3)
将返回包含两个元素的三个列表的列表。
split_list(mylist,4)
将返回两个元素列表和两个元素列表的列表。
我不关心哪个元素出现在哪个列表中,只是列表尽可能均匀地划分。
答案 0 :(得分:2)
numpy.split已经这样做了:
示例:
>>> mylist = np.array([1,2,3,4,5,6])
split_list(mylist,2)将返回两个包含三个元素的列表的列表 - [[1,2,3] [4,5,6]]。
>>> np.split(mylist, 2)
[array([1, 2, 3]), array([4, 5, 6])]
split_list(mylist,3)将返回三个两个列表的列表 元件。
>>> np.split(mylist, 3)
[array([1, 2]), array([3, 4]), array([5, 6])]
split_list(mylist,4)将返回两个元素的两个列表的列表 以及一个元素的两个列表。
当长度(mylist)/ n的余数不为0时,您可能希望为这些情况添加异常捕获:
>>> np.split(mylist, 4)
ValueErrorTraceback (most recent call last)
----> 1 np.split(mylist, 4)
...
ValueError: array split does not result in an equal division