`

python中的map,filter,reduce,lambda

 
阅读更多

Python 内置了一些非常有趣但非常有用的函数,充分体现了Python的语言魅力!

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]

>>> def f(x): return x != 'a'
>>> filter(f, "abcdef")
'bcdef'

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]

>>> def cube(x) : return x + x
...
>>> map(cube , "abcde")
['aa', 'bb', 'cc', 'dd', 'ee']

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

>>> def add(x, y): return x+y
>>> map(add, range(8), range(8))
[0, 2, 4, 6, 8, 10, 12, 14]

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

>>> def add(x,y): return x + y
>>> reduce(add, range(1, 11))
55 (注:1+2+3+4+5+6+7+8+9+10)

>>> reduce(add, range(1, 11), 20)
75 (注:1+2+3+4+5+6+7+8+9+10+20)

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

 

 

 

python有几个内置的函数很有意 思:map/filter/reduce,都是对一个集合进行处理,filter很容易理解用于过滤,map用于映射,reduce用于归并. 是python列表方法的三架马车。
  • filter() 函数:
    filter 函数的功能相当于过滤器。调用一个布尔函数bool_func来迭代遍历每个seq中的元素;返回一个使bool_seq返回值为true的元素的序列。

    >>> a = [ 1 , 2 , 3 , 4 , 5 , 6 , 7 ]
    >>> b= filter (lambda   x : x > 5 ,   a )
    >>> print   b
    >>> [ 6 , 7 ]
    如果filter参数值为None,就使用identity()函数,list参数中所有为假的元 素都将被删除。如下所示:
    >>> a = [ 0 , 1 , 2 , 3 , 4 , 5 , 6 , 7 ]
    >>> b= filter (None ,   a )
    >>> print   b
    >>> [ 1 , 2 , 3 , 4 , 5 , 6 , 7 ]

  • map() 函数:
map函数func作用于给定序列的每个元素,并用一个列表来提供返回值。
>>> map (lambda   x : x + 3 ,   a )  #这里的a同上
>>> [ 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 ]

#另一个例子
>>> a = [ 1 , 2 , 3 ]
>>> b= [ 4 , 5 , 6 ]
>>> map (lambda   x , y : x + y ,   a , b)
>>> [ 5 , 7 , 9 ]

  • reduce() 函数:
reduce函数,func为二元函数,将func作用于seq序列的元素,每 次携带一对(先前的结果以及下一个序列的元素),连续的将现有的结果和下一个值作用在获得的随后的结果上,最后减少我们的序列为一个单一的返回值。
>>> a   =   [ 1 , 2 , 3 , 4 , 5 ]
>>> reduce (lambda   x , y : x + y , a )
15
分享到:
评论

相关推荐

    Python lambda表达式filter、map、reduce函数用法解析

    主要介绍了Python lambda表达式filter、map、reduce函数用法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

    简单了解python filter、map、reduce的区别

    这篇文章主要介绍了简单了解python filter、map、reduce的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 python中有一些非常有趣的函数,面试的时候可能...

    Python中的特殊语法:filter、map、reduce、lambda介绍

    主要介绍了Python中的特殊语法:filter、map、reduce、lambda介绍,本文分别对这个特殊语法给出了代码实例,需要的朋友可以参考下

    map、reduce、filter 、lambda 使用

    print(list(map(lambda x:x*2,[i for i in range(9)]))) [0, 1, 2, 3, 4, 5, 6, 7, 8] [0, 2, 4, 6, 8, 10, 12, 14, 16] 二、reduce函数 同样接受两个参数 函数和可迭代对象 不过reduce会将第一个执行结果会和后面...

    Python内置函数之filter map reduce介绍

    Python内置了一些非常有趣、有用的函数,如:filter、map、reduce,都是对一个集合进行处理,filter很容易理解用于过滤,map用于映射,reduce用于归并. 是Python列表方法的三架马车。 1. filter函数的功能相当于...

    Python函数的返回值、匿名函数lambda、filter函数、map函数、reduce函数用法实例分析

    本文实例讲述了Python函数的返回值、匿名函数lambda、filter函数、map函数、reduce函数用法。分享给大家供大家参考,具体如下: 函数的返回值: 函数一旦执行到 return,函数就会结束,并会返回return 后面的值,...

    Python的lambda表达式.pdf

    文档中详细介绍了lambda表达式的基本语法和使用方式,以及如何将lambda表达式与其他Python语言特性结合使用,如map()函数、filter()函数和reduce()函数等。同时,文档中还提供了多个实例演示和代码案例,让读者可以...

    Pythont特殊语法filter,map,reduce,apply使用方法

    这篇文章主要介绍了Pythont特殊语法filter,map,reduce,apply使用方法,需要的朋友可以参考下 (1)lambda lambda是Python中一个很有用的语法,它允许你快速定义单行最小函数。类似于C语言中的宏,可以用在任何需要...

    python、lambda表达式的用法举例 .txt 文本格式

    2.与map()、 filter()和 reduce()等高阶函数配合 3.赋予key参数使用 4.直接调用 5.闭包中使用 6、其它: 适合人群:初级、中级 python语言学习者 能学到什么:学习python中lambda表达式的语法、各种常见的用法。 ...

    python- 笔记 高阶函数map reduce fileter

    python 高阶函数:map reduce filter map函数:遍历序列,对序列中每个元素进行操作,最终获取新的序列。 reduce函数:对于序列内所有元素进行累计操作。 filter函数:对于序列中的元素进行筛选,最终获取符合条件的...

    Python编码风格指南(中文版)

    2.10 使用 apply filter map reduce 2.11 Lambda functions 2.12 默认参数值 2.13 Properties 2.14 布尔内置类型 2.15 String 方法 2.16 静态域 2.17 函数和方法修饰符 2.18 线程 2.19 高级特性 3. Python 编码风格...

    在Python中使用lambda高效操作列表的教程

    map()/filter()/reduce() 需要两个参数,第一个是一个处理函数,第二个是一个序列(list,tuple,dict) map() 将序列中的元素通过处理函数处理后返回一个新的列表 filter() 将序列中的元素通过函数过滤后返回一个新的...

    python编程设计.docx

    Python中的lambda表达式、map、reduce、filter等函数式编程的特性,使得Python可以更加简洁、优雅地处理数据。 Python编程设计的第三个重要方面是模块化编程,这是一种将程序分解为独立的模块,每个模块都有自己的...

    初学者python笔记(匿名函数、map()函数、reduce()函数、filter()函数)

    本篇是对Python中的匿名函数和map()函数、reduce()函数、filter()函数这四三大封装函数(遍历处理),以及它们的使用案例。 文末是对这几个函数用法功能的比较。 匿名函数 该函数的用法类似于C语言中的宏定义,只是这...

    coldnight#coldnight.github.com#lambda-结合map-filter-reduce-sorted

    介绍Python用于支持将函数赋值给变量的一个操作符默认是返回的,所以不用再加return关键字,不然会报错需要两个参数,第一个是一个处理函数,第二个是一个序列

Global site tag (gtag.js) - Google Analytics