Python----map,filter,reduce,zip,lambda的使用方法

简介: Python----map,filter,reduce,zip,lambda的使用方法

【原文链接】

map,filter,reduce,zip都是处理序列的便捷的内置函数

1 map(func,iterable)

map的作用主要是将一个函数应用于一个可迭代的序列,然后将返回值返回

a=[1,2,3,4,5,6]
def func(x):
    return x*x

b=map(func,a)
print(list(b))

运行结果为:

[1, 4, 9, 16, 25, 36]

2 filter(func,iterable)

filter的功能是通过func来对可迭代的序列进行过滤,如果func的返回值为真,则对应的iterable中的值保留下来,最后一起以序列的形式返回

a=[1,2,3,4,5,6]
def func(x):
    return x%2==0

b=filter(func,a)
print(list(b))

执行结果如下所示:

[2, 4, 6]

3 reduce(func,iterable)

reduce 的功能是股东计算应用于可迭代序列iterable的结果,最后将结果返回,非常适合应用类似累加和累乘的场景

from functools import reduce

a=[1,2,3,4,5,6]
def add(x,y):
    return x+y

def multi(x,y):
    return x*y
b=reduce(add,a)
c=reduce(multi,a)
print(b)
print(c)

执行结果如下:

21
720

4 zip(*iterable)

zip的功能是映射多个容器的相似索引,可以方便用于来构造字典

a=[1,2,3,4,5]
b=["a","b","c","d","e"]
c=dict(zip(b,a))
print(c)

执行结果为:

{'a': 1, 'b': 2, 'c': 3, 'd': 4, 'e': 5}

灵活地应用这几个内置函数,有时候可以是代码更加简洁

5 匿名函数

lambda 表达式其实就是匿名函数,在很多比如定义一个函数,函数的功能比较简单同时又只会用一次,这时候如果像普通定义函数那样定义,总会有种不划算的感觉,这时候匿名函数的作用就来了,通过使用lambda表示定义个匿名函数,即达到了函数的功能,同时又没有定义函数

为了更好的理解匿名函数,下面先通过一个普通的函数定义来看一下

def add(a,b):
    return (a+b)

temp=add(100,200)
print(temp)

显然,执行结果为300,下面采用lambda表达式来达到同样的效果

f=lambda x,y:x+y
print(f(100,200))

结果同上面定义函数的方式是一样的,lambda表达式其实也挺简单的,冒号前面的就可以理解为参数的形参,冒号后面就可以理解函数的返回值

6 lambda表达式通常和map,filter,zip,reduce等结合起来一起用非常方便

下面看个例子

a=[1,2,3,4,5,6]

print(list(map(lambda x:x*x,a)))

执行结果为:

[1, 4, 9, 16, 25, 36]

代码非常的简洁

在一些开源库中,lambda表达式也经常被使用,所以这里专门把lambda表达式拿出来讲解一下

目录
相关文章
WK
|
7月前
|
Python
Python中format_map()方法
在Python中,`format_map()`方法用于使用字典格式化字符串。它接受一个字典作为参数,用字典中的键值对替换字符串中的占位符。此方法适用于从字典动态获取值的场景,尤其在处理大量替换值时更为清晰和方便。
WK
255 36
|
9月前
|
索引
ES5常见的数组方法:forEach ,map ,filter ,some ,every ,reduce (除了forEach,其他都有回调,都有return)
ES5常见的数组方法:forEach ,map ,filter ,some ,every ,reduce (除了forEach,其他都有回调,都有return)
|
8月前
|
存储 大数据 Python
案例学Python:filter()函数的用法,高级!
`filter()`函数是Python中处理序列数据的强大工具,它允许我们高效地根据条件过滤元素。通过结合匿名函数、常规函数或直接利用Python的内置逻辑,`filter()`提供了灵活且高效的过滤机制,尤其在大数据处理和内存敏感的应用中展现出其价值。掌握 `filter()`的使用,不仅能提升代码的可读性和效率,还能更好地适应Python的函数式编程风格。
184 2
|
9月前
|
JavaScript 前端开发
js map和reduce
js map和reduce
|
9月前
|
Python
Python函数式编程-Filter
Python函数式编程-Filter
|
11月前
|
人工智能 算法 大数据
算法金 | 推导式、生成器、向量化、map、filter、reduce、itertools,再见 for 循环
这篇内容介绍了编程中避免使用 for 循环的一些方法,特别是针对 Python 语言。它强调了 for 循环在处理大数据或复杂逻辑时可能导致的性能、可读性和复杂度问题。
111 6
算法金 | 推导式、生成器、向量化、map、filter、reduce、itertools,再见 for 循环
|
11月前
|
开发者 Python
Python函数与模块使用方法
【7月更文挑战第24天】Python 是一种功能强大的编程语言,拥有丰富的函数和模块,使得开发者能够轻松地构建复杂的应用程序。本文将介绍 Python 中函数和模块的基本使用方法,并提供一些代码实例。
110 3
|
11月前
|
JavaScript API
js【最佳实践】遍历数组的八种方法(含数组遍历 API 的对比)for,forEach,for of,map,filter,reduce,every,some
js【最佳实践】遍历数组的八种方法(含数组遍历 API 的对比)for,forEach,for of,map,filter,reduce,every,some
226 1
|
10月前
|
分布式计算 Python
【python笔记】高阶函数map、filter、reduce
【python笔记】高阶函数map、filter、reduce
107 0
|
10月前
|
Python
【python笔记】使用zip函数迭代多个可迭代对象
【python笔记】使用zip函数迭代多个可迭代对象

推荐镜像

更多