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个小列表的内容。
来源:https://www.cnblogs.com/felixz/p/15512125.html
图文来源于网络,如有侵权请联系删除。