如何在python中将列表拆分为给定数量的子列表

时间:2010-02-10 09:02:30

标签: python list

  

可能重复:
  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)将返回两个元素列表和两个元素列表的列表。

我不关心哪个元素出现在哪个列表中,只是列表尽可能均匀地划分。

1 个答案:

答案 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