Python 内置函数 -- zip(), sorted(), filter()和map()
内置函数
1. zip() 打包(木桶效应)
描述: zip() 函数用于将可迭代的对象作为参数, 将对象中对应的元素打包成一个个元组, 然后返回由这些元组组成的列表
语法: zip([iterable, ...])
参数: iterable -- 一个或多个迭代器
返回值: 返回可迭代对象
# 实例:
lst1 = ["中国", "美国", "俄罗斯", "日本"]
lst2 = ["北京", "华盛顿", "莫斯科"]
lst3 = ["烤鸭", "炸鸡", "黄油+面包", "寿司"]
lst = zip(lst1, lst2, lst3) # 合并列表, 返回可迭代对象, 水桶效应
print(lst)
print(list(lst))
print("__iter__" in dir(lst))
输出结果:
<zip object at 0x0000005E0A4DCEC8>
[('中国', '北京', '烤鸭'), ('美国', '华盛顿', '炸鸡'), ('俄罗斯', '莫斯科', '黄油+面包')]
True 需要注意的是:
(1)zip()函数具有水桶效应
(2)zip()函数返回的是一个迭代器, 直接打印zip()函数的结果是一个内存地址 2. sorted() 排序
执行流程: 把可迭代对象iterable中的每一个元素拿出来, 放到func中运行, 返回一个数字, 根据数字进行排序
描述: sorted() 函数对所有可迭代的对象进行排序操作
语法: sorted(iterable, key=func, reverse=True/False)
参数说明: iterable -- 可迭代对象
func -- 排序规则
reverse=True表示降序排列, reverse=False表示升序排列
返回值: 返回排序后的列表 实例1:
lst = ["王乃卉", "刘能", "赵四", "王大拿", "范伟", "沈腾"]
lst1 = sorted(lst, key=lambda name: len(name) % 3)
print(lst1)
输出结果:
['王乃卉', '王大拿', '刘能', '赵四', '范伟', '沈腾'] 实例2:按照年龄对学⽣信息进行排序
lst = [
{"id": 1, "name": 'alex', "age": 18},
{"id": 2, "name": 'wusir', "age": 16},
{"id": 3, "name": 'taibai', "age": 17},
] l2 = sorted(lst, key=func)
print(l2)
l3 = sorted(lst, key=lambda dic: dic['age'])
l4 = sorted(lst, key=lambda dic: len(dic['name']))
l5 = sorted(lst, key=lambda dic: ascii(dic['name'][0]))
print(l5)
sorted()函数最大的优点是可以按照自己的规则(自己定义的函数)来排序 3. filter() 筛选
执行流程: 把可迭代对象中的每一个元素拿出来, 放到func中运行, 返回True或False, 根据返回的True和False来决定这个元素是否保留
描述: filter() 函数用于过滤序列, 过滤掉不符合条件的元素, 返回由符合条件的元素组成的迭代器
语法: filter(function, iterable)
参数: function -- 判断函数
iterable -- 可迭代对象
返回值: 返回迭代器
注意: filter()的作用是筛选,所以function的功能是判断 实例:
(本题会用到lambda匿名函数, 如果不了解请点击这里)
lst = [23, 28, 15, 27, 24, 22]
f = filter(lambda age: age > 18 and age % 2 == 0, lst)
print(list(f)) # 要把返回的迭代器转换成列表才能打印出来
4. map() 映射
执行流程: 把可迭代对象中的每一个元素拿出来, 放到func中运行, 返回数据就是结果
描述: map()会根据提供的函数对指定序列做映射
语法: map(function, iterable, ...)
参数: function -- 函数
iterable -- 一个或多个序列
返回值: 返回迭代器
注意: map()的作用是映射,所以function的功能是作为对应法则输出目标值 实例1:
lst = [1,5,9,3]
m = map(lambda x: x**2, lst)
print(list(m))
输出结果:
[1, 25, 81, 9] 实例2:计算两个列表相同位置的数据的和
lst1 = [1, 2, 3, 4, 5]
lst2 = [2, 4, 6, 8, 10]
print(list(map(lambda x, y: x + y , lst1, lst2)))
输出结果:
[3, 6, 9, 12, 15]
Python 内置函数 -- zip(), sorted(), filter()和map()的更多相关文章
- python内置函数lambda、filter、map、reduce
lambda匿名函数 1.lambda只是一个表达式,函数体比def简单多. 2.lambda的主体是一个表达式,而不是一个代码块.仅仅能在lambda表达式中封装有限的逻辑进去 3.lambda函数 ...
- python 内置函数zip,map,三元,lambda表达式
#内置函数zip(),将多个可迭代对象(集合等)按照顺序进行组合成tuple元祖,放在zip 对象进行存储,: #当参数为空时候,返回空 #如果 zip() 函数压缩的两个列表长度不相等,那么 zip ...
- python之内置函数(lambda,sorted,filter,map),递归,二分法
一.lambda匿名函数 为了解决一些简单需求而设计的一句话函数,lambda表示的是匿名函数,不需要用def来声明,一句话就可以声明出一个函数. 语法: 函数名 = lambda 参数 : 返回值 ...
- 内置函数 lambda sorted filter map 递归
一 lambda 匿名函数 为了解决一些简单的需求而设计的一句话函数 # 计算 n 的 n次方 def func(n): return n**n print(func(10)) f = lambda ...
- python内置函数:sorted中的参数key
x.sort和sorted函数中参数key的使用 介绍 python中,列表自带了排序函数sort >>> l = [1, 3, 2] >>> l.sort() & ...
- python内置函数zip
zip() 函数用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的列表. 如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同,利用 * 号操作符,可以 ...
- 内置函数之sorted,filter,map
# 4,用map来处理字符串列表,把列表中所有人都变成sb,比方alex_sb # name=['oldboy','alex','wusir'] # print(list(map(lambda i:i ...
- Python内置函数(37)——sorted
英文文档: sorted(iterable[, key][, reverse]) Return a new sorted list from the items in iterable. Has tw ...
- Python内置函数(59)——sorted
英文文档: sorted(iterable[, key][, reverse]) Return a new sorted list from the items in iterable. Has tw ...
随机推荐
- 数据结构系列文章之队列 FIFO
转载自https://mp.weixin.qq.com/s/ILgdI7JUBsiATFICyyDQ9w Osprey 鱼鹰谈单片机 3月2日 预计阅读时间: 6 分钟 这里的 FIFO 是先入先出 ...
- django缓存--缓存加数据库型
4.缓存+数据库Session 数据库用于做持久化,缓存用于提高效率 a. 配置 settings.py SESSION_ENGINE = 'django.contrib.sessio ...
- 【Android-网络通讯】 客户端与.Net服务端Http通讯
以登陆系统为例: 一.创建服务端程序 1.打开VS2012,新建项目,创建ASP.NET WEB应用程序 ,命名为MyApp 2.添加新建项,选择一般处理程序,创建Login.ashx C# Code ...
- react-native-pg-utils(对react-native全局进行配置,对内置对象原型链增加方法,增加常用全局方法.)
react-native-pg-utils 对react-native全局进行配置,对内置对象原型链增加方法,增加常用全局方法. 每次新建react-native项目之后都会发现有一些很常用的方法在这 ...
- 【Android】查看内存
[文章来源]http://blog.csdn.net/hudashi/article/details/7050897 查看内存使用的方式有很多种,但是各个方式查看到的结果可能会有微略不同. 方式一 ...
- 【poj1733】Parity game--边带权并查集
Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 15776 Accepted: 5964 Description Now ...
- Java的23种设计模式<一>
设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了可重用代码.让代码更容易被他人理解.保证代 码可靠性. 毫无疑问,设计模式 ...
- Linux+CLion+树莓派远程编译时,Cmake编译出现undefined reference to 'pthread_create'的解决办法
在CLion中开发讯飞的linux语音库时编译出现以下问题: undefined reference to 'pthread_create' CLion的cmake配置:修改CMakeLists.tx ...
- mysql数据库的索引
什么是索引 索引就是一种优化查询的数据结构: 为什么要加索引 因为创建索引可以大大提高系统的查询性能. 怎么提高查询性能的 简单的理解:一张数据量比较大的表格如果没有添加任何索引,那我们在执行查询的时 ...
- FutureTask用法及解析
1 FutureTask概念 FutureTask一个可取消的异步计算,FutureTask 实现了Future的基本方法,提空 start cancel 操作,可以查询计算是否已经完成,并且可以获取 ...