Python 函数 filter() map() reduce()

1.filter(bool_func,seq)

filter()是‘筛选函数’,也接收一个函数和一个序列,filter()把传人的函数依次作用于序列的每个元素,然后根据返回值是True还是false决定保留还是丢弃该元素

例子:

  1. def fr(x):
  2. return x%2==1
  3. print ‘filter1:‘,filter(fr,range(1,51))#筛选出100以内的所有奇数
  4. print ‘filter2:‘,filter(fr,[1,2,3,4])

输出:

filter1: [1, 3, 5, 7, 9, 11, 13, 15, 17, 19, 21, 23, 25, 27, 29, 31, 33, 35, 37, 39, 41, 43, 45, 47, 49]
           filter2: [1, 3]

filter内建函数的Python实现:

  1. >>> def filter(bool_func,seq):
  2. filtered_seq = []
  3. for eachItem in seq:
  4. if bool_func(eachItem):
  5. filtered_seq.append(eachItem)
  6. return filtered_seq

2、map(func,seq1[,seq2...])

map():将函数func作用于给定序列的每个元素,并用一个列表来提供返回值;如果func为None,func表现为身份函数,返回一个含有每个序列中元素集合的n个元组的列表。

  1. >>> map(lambda x : None,[1,2,3,4])
  2. [None, None, None, None]
  3. >>> map(lambda x : x * 2,[1,2,3,4])
  4. [2, 4, 6, 8]
  5. >>> map(lambda x : x * 2,[1,2,3,4,[5,6,7]])
  6. [2, 4, 6, 8, [5, 6, 7, 5, 6, 7]]
  7. >>> map(lambda x : None,[1,2,3,4])
  8. [None, None, None, None]

map内建函数的python实现:

  1. >>> def map(func,seq):
  2. mapped_seq = []
  3. for eachItem in seq:
  4. mapped_seq.append(func(eachItem))
  5. return mapped_seq

3.reduce(func,seq[,init])

reduce():func为二元函数,将func作用于seq序列的元素,每次携带一对(先前的结果以及下一个序列的元素),连续的将现有的结果和下一个值作用在获得的随后的结果上,最后减少我们的序列为一个单一的返回值:如果初始值init给定,第一个比较会是init和第一个序列元素而不是序列的头两个元素。

  1. >>> reduce(lambda x,y : x + y,[1,2,3,4])
  2. 10
  3. >>> reduce(lambda x,y : x + y,[1,2,3,4],10)
  4. 20

reduce的python实现:

  1. >>> def reduce(bin_func,seq,initial=None):
  2. lseq = list(seq)
  3. if initial is None:
  4. res = lseq.pop(0)
  5. else:
  6. res = initial
  7. for eachItem in lseq:
  8. res = bin_func(res,eachItem)
  9. return res
时间: 2024-08-06 07:59:25

Python 函数 filter() map() reduce()的相关文章

python中filter, map, reduce, lambda

python 中内置的几个函数filter, map, reduce, lambda简单的例子. #!/usr/bin/env python #_*_coding:utf-8_*_ #filter(function, sequence): #对sequence中的item依次执行function(item),将执行结果为True的item组成一个List/String/Tuple(取决于sequence的类型)返回. #可以看作是过滤函数. tasks = [ { 'id': 1, 'title

python——lambda,filter,map,reduce

lambda函数 使用方法:lambda [arg1[,arg2,arg3,...,argn]] : expression 如: add = lambda(x,y:x+y) add(1,2) 结果为1+2=3 filter函数 filter(bool_func,seq) 此函数的功能相当于过滤器,通过返回值为bool的函数bool_func来迭代遍历seq中的每个元素: 结果返回一个seq中使bool_func返回值为true的元素的序列. filter(lambda x : x%2 == 0,

Python内置函数filter, map, reduce

filter.map.reduce,都是对一个集合进行处理,filter很容易理解用于过滤,map用于映射,reduce用于归并. 是Python列表方法的三架马车. 1. filter函数的功能相当于过滤器. filter函数的定义: filter(function or None, sequence) -> list, tuple, or string function是一个谓词函数,接受一个参数,返回布尔值True或False. filter函数会对序列参数sequence中的每个元素调用

python关于list的三个内置函数filter(), map(), reduce()

''' Python --version :Python 2.7.11 Quote : https://docs.python.org/2/tutorial/datastructures.html#more-on-lists Add by camel97 2017-04 ''' 1.filter() #filter(function, sequence) returns a sequence consisting of those items from the sequence for whic

python内置函数filter(),map(),reduce()笔记

'''python reduce()函数:reduce()函数会对参数序列中元素进行积累. 函数将一个数据集合(链表,元组等)中的所有数据进行下列操作:用传给reduce中的函数 function(有两个参数)先对集合中的第 1.2 个元素进行操作,得到的结果再与第三个数据用 function 函数运算,最后得到一个结果. 语法:ruduce()reduce(function,iterable,initializer)参数:function-函数,有两个参数iterable--可迭代对象init

Python 内置函数&filter()&map()&reduce()&sorted()

常用内置函数 Python 2.x 返回列表,Python 3.x 返回迭代器 在进行筛选或映射时,输出的结果是一个数组,需要list帮助. 如:print(list(map(lambda x:x+1, [1,2,3]))) 一.filter() --过滤.筛选 刚接触filter时 ,运行总是出现<filter object at 0x000001B68F052828> 得不到想要的数据,后来发现是因为filter的结果是一个数组, 需要 list 帮助,后来将print(f) 改为 pri

python|高级函数|filter|map|reduce|sorted

filter(func, iterable) 循环调用输入的函数 过滤传入的参数,函数的结果返回的是true那就保存,返回false就不要,且返回的也是迭代器 备注: 迭代器用完一个就扔掉一个,直到全部用完: 可以用list()转化为列表:不转化则返回的为迭代器对象,可以用for循环直接逐个调用 # utils/core.py convert_legacy_filters_into_adhoc()for filt in filter(lambda x: x is not None, fd[fil

ES6高阶函数:过滤器&gt;&gt;filter, map,reduce

1 // 高阶函数 filter/map/reduce 2 3 // filter中的回调函数有一个要求:必须返回一个boolean值, 4 // 当返回true时,函数内部会自动将这次回调的 n 加入到新的数组中 5 // 当返回false时,函数内部会自动过滤掉这次的 n 6 const nums=[10,20,60,94,348,57,24,674,645,44,4] 7 let newNums = nums.filter(function (n){ 8 return n<30 9 })

Python经常使用内置函数介绍【filter,map,reduce,apply,zip】

Python是一门非常简洁,非常优雅的语言,其非常多内置函数结合起来使用,能够使用非常少的代码来实现非常多复杂的功能,假设相同的功能要让C/C++/Java来实现的话,可能会头大,事实上Python是将复杂的数据结构隐藏在内置函数中,用C语言来实现,所以仅仅要写出自己的业务逻辑Python会自己主动得出你想要的结果.这方面的内置函数主要有,filter,map,reduce,apply,结合匿名函数,列表解析一起使用,功能更加强大.使用内置函数最显而易见的优点是: 1. 速度快,使用内置函数,比