Python中map和reduce详解

来源:互联网 发布:中国网络直播行业协会 编辑:程序博客网 时间:2024/06/06 03:56

map()函数接收两个参数,一个是函数,一个是序列,map将传入的函数依次作用到序列的每个元素,并把结果作为新的list返回。

实例:map(str, [1, 2, 3, 4, 5, 6, 7, 8, 9])=['1', '2', '3', '4', '5', '6', '7', '8', '9']

reduce()把一个函数作用在一个序列[x1, x2, x3...]上,这个函数必须接收两个参数,reduce把结果继续和序列的下一个元素做累积计算,其效果就是:

reduce(f, [x1, x2, x3, x4]) = f(f(f(x1, x2), x3), x4)

实例:reduce(add, [1, 3, 5, 7, 9])=25

还可嵌套使用:reduce(lambda x,y: x*10+y, map(int, ['1','2','3','4','5']))

map()实例:利用map()函数,把用户输入的不规范的英文名字,变为首字母大写,其他小写的规范名字

def normalize(name):  
   name=name[0].upper()+name[1:].lower()  
   return name  
a= ['adam', 'LISA', 'barT']  
b= list(map(normalize, a))  
print(b)  


原创粉丝点击