代码
# Python列表按顺序进行分块
# len_data_list: 数据列表的个数
# n_block: 数据列表需要划分的块数(如分为3块,则有第0块,第1块,第2块)
def block_list(len_data_list, n_block):
# 获取每块的元素个数
average = int(len_data_list / n_block)
# 用于保存各块起止索引
interval_list = []
for i in range(n_block):
# 获取第i块的起止索引
begin, end = i * average, (i + 1) * average
# 最后一块(之前的块的数据元素个数相同,最后一块则最多比前面的块的元素个数多n_block个)
if i == n_block - 1:
end = len_data_list
# 保存各块的起止索引
interval_list.append((begin, end))
return interval_list
# 获取位于[begin, end)区间的子列表
def get_block_i(data_list, interval):
begin, end = interval
return data_list[begin: end]
# 程序入口
if __name__ == '__main__':
# 设置一个数据列表
name_list = ['Tom', 'Jack', 'Sunny', 'Jenny', 'Lily', 'Ming', 'Larry', 'Camera', 'Max', 'Mix', 'Blue', 'Lord', 'Tek', 'Ten', 'Fans', 'Red', 'Pink', 'Black']
# 对数据列表进行划分(通过起止索引的方式)
li = block_list(len(name_list), 3)
# 获取每一块的数据
for i in range(len(li)):
# 获取第i块数据
b, e = li[i]
block_i = get_block_i(name_list, (b, e))
# 使用第i块数据(这里仅打印)
print(block_i)
输出
['Tom', 'Jack', 'Sunny', 'Jenny', 'Lily', 'Ming']
['Larry', 'Camera', 'Max', 'Mix', 'Blue', 'Lord']
['Tek', 'Ten', 'Fans', 'Red', 'Pink', 'Black']