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
个小列表的内容。