filter、map、reduce、lambda[通俗易懂]

filter、map、reduce、lambda

大家好,又见面了,我是全栈君。

1. filter(function, sequence):对sequence中的item依次执行function(item),将执行结果为True的item组成一个List/String/Tuple(取决于sequence的类型)返回

def f(x): 
    return x % 2 != 0 and x %3 != 0
filter(f, range(2,25))

输出:

[5, 7, 11, 13, 17, 19, 23]

2. map(function, sequence) :对sequence中的item依次执行function(item),将执行结果组成一个List返回:

def cube(x):
    return x*x*x
map(cube, range(1,11))

输出:

[1, 8, 27, 64, 125, 216, 343, 512, 729, 1000]

另外map也支持多个sequence,这就要求function也支持相应数量的参数输入:

def add(x, y):
    return x+y
map(add, range(8), range(8))

输出:

[0, 2, 4, 6, 8, 10, 12, 14]

3. reduce(function, sequence, starting_value):对sequence中的item顺序迭代调用function,如果有starting_value,还可以作为初始值调用,例如可以用来对List求和:

def add(x, y):
    return x+y
reduce(add, range(1,11))

输出:

55

设定初始值

reduce(add, range(1, 11), 20) 

输出:

75

4. lambda:这是Python支持一种有趣的语法,它允许你快速定义单行的最小函数,类似与C语言中的宏,这些叫做lambda的函数,是从LISP借用来的,可以用在任何需要函数的地方: 

g = lambda x: x * 2 
g(3)

输出:

6

 

 

 

 

 

 

 

 

 

 

 

转载于:https://my.oschina.net/xiaohuangsh/blog/829271

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/108681.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号