map,reduce,zip是经常会用到的3个内置函数,以简洁的语言总结一下
map(f,iterable)
map会对可迭代对象 iterable(list,tuple等)中的每个元素进行 f函数 操作,返回一个迭代器
sum = map(lambda x:x*x,[1,2,3]) #map是个迭代器
print(list(sum)) #[1, 4, 9]
当然还可以传 2 个 iterable 对象,此时对2个 iterable对象对应的位置元素做 f函数 操作。
sum = map(lambda x,y:x+y,[1,2,3],[4,5,6]) #map是个迭代器
print(list(sum)) #[5, 7, 9]
reduce(f,iterable)
reduce会对可迭代对象 iterable(list,tuple等)中的每2个元素进行 f函数 操作,得到结果后与后续元素继续进行 f函数 操作,直到最后一个元素。简单来说就是在 iterable 所有元素之间做 f函数 操作
from functools import reduce
sum = reduce(lambda x,y:x+y,[1,2,3])
print(sum) # 6
当然 renduce 也可以传递3个参数,reduce以后的结果和最后一个元素进行 f函数 操作
from functools import reduce
sum = reduce(lambda x,y:x*y,[1,2,3],2)
print(sum) # 12
但是对于元素相减来说,reduce是按照相加来计算的,具体来说,就是对 iteiterable 所有元素之间先进行 + 操作,最后和第 3 个参数相加
from functools import reduce
sum = reduce(lambda x,y:x-y,[2,2,3],-1)
print(sum) # -(2+2+3)+(-1)=-8 而不是 2-2-3-(-1)=-2
zip(iterable,iterable,...)
zip是将每个 iterable 对应位置元素组成元组,最后返回元组的列表(zip对象),如果要看到内容,需要使用 *zip对象 解压缩
print(*zip([1,2,3],[4,3,5],[1,2,5])) #(1, 4, 1) (2, 3, 2) (3, 5, 5)
如果压缩对象之间长度不等,将按照长度短的压缩。