今天写一个任务调度分发模块的时候遇上一个需求就是,需要将输入的任务列表分割进而创建子任务列表,每个子任务数量相同,这就是一个均分的问题,很简单,不多说,使用Python来做很简单,下面是两种做法的简单实现:
def test1(one_data_list,colnum=3):
'''
将一维的列表转化为矩阵形式
'''
res_list=[]
for i in range(0,len(one_data_list),colnum):
res_list.append(one_data_list[i:i+colnum])
return res_listdef test2(one_list,c=3):
'''
将一个长度为n的列表划分 ,每个子列表中包含m个元素
'''
return [one_list[i:i+c] for i in range(len(one_list)) if i%c==0]简单测试一下:
one_data_list=[1,2,3,4,5,6,7,8,9]
print test1(one_data_list,colnum=3)
print test2(one_data_list,c=3)
[[1, 2, 3], [4, 5, 6], [7, 8, 9]]
[[1, 2, 3], [4, 5, 6], [7, 8, 9]]

本文介绍了一种使用Python将一个长列表均分为多个子列表的方法,并提供了两种不同的实现方式,适用于需要将任务列表拆分成若干个子任务列表的场景。
737

被折叠的 条评论
为什么被折叠?



