头图
Python 代码阅读合集介绍:为什么不推荐Python初学者直接看项目源码

本篇阅读的代码实现了将列表分割成指定大小的小列表的功能。最后一个小列表的长度由实际剩余的项而定。

本篇阅读的代码片段来自于30-seconds-of-python

chunk

from math import ceil

def chunk(lst, size):
  return list(
    map(lambda x: lst[x * size:x * size + size],
      list(range(0, ceil(len(lst) / size)))))

# EXAMPLES
chunk([1, 2, 3, 4, 5], 2) # [[1,2],[3,4],[5]]

chunk函数接收一个列表和一个规模参数,返回分割后的小列表。函数使用list()range()来创建一个序号列表,指明分割后的列表序号。在序号列表上使用map()并用输入列表的切片来填充它。最后,返回新创建的列表。

math.ceil(x)函数返回x的上限,即大于或者等于x的最小整数。输入列表的长度无法被分割规模整除的时候,最后剩余的项仍然会合并成一个列表,所以,这里需要使用math.ceil(x)获取大于或者等于 (len(lst) / size)的最小整数。

函数通过list()range()生成长度为小列表个数的序号列表(从0开始),输入列表lst的切片lst[x * size:x * size + size]就是第x个小列表的内容。


Felix
3 声望1 粉丝