前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >#抬抬小手学Python# Python 之内置函数:filter、map、reduce、zip、enumerate

#抬抬小手学Python# Python 之内置函数:filter、map、reduce、zip、enumerate

原创
作者头像
查理不是猹
发布2022-01-04 14:21:10
2640
发布2022-01-04 14:21:10
举报

filter、map、reduce、zip、enumerate

=================================

这几个函数在 Python 里面被称为高阶函数,本文主要学习它们的用法。

filter

filter 函数原型如下:

代码语言:txt
复制
filter(function or None, iterable) --> filter object

第一个参数是判断函数(返回结果需要是 True 或者 False),第二个为序列,该函数将对 iterable 序列依次执行 function(item) 操作,返回结果是过滤之后结果组成的序列。

简单记忆:对序列中的元素进行筛选,获取符合条件的序列。

代码语言:txt
复制
my_list = [1, 2, 3]
my_new_list = filter(lambda x: x > 2, my_list)
print(my_new_list)

返回结果为:<filter object at 0x0000000001DC4F98>,使用 list 函数可以输入序列内容。

map

map 函数原型如下:

代码语言:txt
复制
map(func, *iterables) --> map object

该函数运行之后生成一个 list,第一个参数是函数、第二个参数是一个或多个序列;

下述代码是一个简单的测试案例:

代码语言:txt
复制
my_list = [-1,2,-3]
my_new_list = map(abs,my_list)
print(my_new_list)

上述代码运行完毕,得到的结果是:<map object at 0x0000000002860390>。使用 print(list(my_new_list)) 可以得到结果。

map 函数的第一个参数,可以有多个参数,当这种情况出现后,后面的第二个参数需要是多个序列。

代码语言:txt
复制
def fun(x, y):
    return x+y
# fun 函数有2个参数,故需要两个序列
my_new_list = map(fun, [1, 2, 3], [4, 4, 4])
print(my_new_list)
print(list(my_new_list))

map 函数解决的问题:

  1. 使用 map 函数,不需要创建一个空列表;
  2. 调用函数的时候,不需要带括号了,map 函数会自动调用目标函数;
  3. map 函数会自动匹配序列中的所有元素。

reduce

reduce 函数原型如下:

代码语言:txt
复制
reduce(function, sequence[, initial]) -> value

第一个参数是函数,第二个参数是序列,返回计算结果之后的值。该函数价值在于滚动计算应用于列表中的连续值。

测试代码如下:

代码语言:txt
复制
from functools import reduce
my_list = [1, 2, 3]

def add(x, y):
    return x+y

my_new_list = reduce(add, my_list)
print(my_list)
print(my_new_list)

最终的结果是 6,如果设置第三个参数为 4,可以运行代码查看结果,最后得到的结论是,第三个参数表示初始值,即累加操作初始的数值。

代码语言:txt
复制
my_new_list = reduce(add, my_list,4)
print(my_list)
print(my_new_list)

简单记忆:对序列内所有元素进行累计操作。

zip

zip 函数原型如下:

代码语言:txt
复制
zip(iter1 [,iter2 [...]]) --> zip object

zip 函数将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的列表。

如果各个迭代器的元素个数不一样,则返回列表长度与最短的对象相同,利用星号(*)操作符,可以将元组解压为列表。

测试代码如下:

代码语言:txt
复制
my_list1 = [1,2,3]
my_list2 = ["a","b","c"]
print(zip(my_list1,my_list2))
print(list(zip(my_list1,my_list2)))

展示如何利用 * 操作符:

代码语言:txt
复制
my_list = [(1, 'a'), (2, 'b'), (3, 'c')]
print(zip(*my_list))
print(list(zip(*my_list)))

输出结果如下:

代码语言:txt
复制
<zip object at 0x0000000002844788>
[(1, 2, 3), ('a', 'b', 'c')]

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

enumerate

enumerate 函数原型如下:

代码语言:txt
复制
enumerate(iterable, start=0)

参数说明:

  • sequence:一个序列、迭代器或其他支持迭代对象;
  • start:下标起始位置。

该函数用于将一个可遍历的数据对象组合为一个索引序列,同时列出数据和数据下标,一般用在 for 循环当中。

测试代码如下:

代码语言:txt
复制
weekdays = ['Mon', 'Tus', 'Wen', 'Thir']
print(enumerate(weekdays))
print(list(enumerate(weekdays)))

返回结果为:&lt;enumerate object at 0x0000000002803AB0&gt;

这篇博客的总结

本文涉及的函数可以与 lambda 表达式进行结合,能大幅度提高编码效率。最好的学习资料永远是官方手册

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档