python filtermapreducezip

news/2024/12/5 8:13:22/

一、filter 过滤

filter 过滤, 从可迭代对象中,筛选出满足条件的元素,再将这些满足条件的元素,组成一个新的可迭代对象。

方式一:filter(过滤方法,可迭代对象)

举例:将一个list中的偶数,全部筛选出来

def filter_int(x:int):if x % 2 == 0:return Truereturn Falselist = [1,2,3,4,5,6]if __name__ == '__main__':new_filter = filter(filter_int,list) # 得到的是一个filter对象,filter对象是可迭代对象for i in new_filter:print(i)# list1 = list(new_filter)# print(list1) # 将可迭代对象,转成list

new_filter = filter(filter_int,list) # 得到的是一个filter对象,filter对象是可迭代对象

方式二:filter 使用lambda 表达式

filter(lambda 变量名称: 筛选条件,可迭代对象)

list = [1,2,3,4,5,6]if __name__ == '__main__':new_filter = filter(lambda x: x%2==0,list)for i in new_filter:print(i)

new_filter = filter(lambda x: x%2==0,list) # 得到的是一个filter对象,filter对象是可迭代对象

二、map 映射

2.1 处理一个可迭代对象

map(lambda 变量:处理逻辑,可迭代对象)

map依次,对可迭代对象里的元素做处理。

map_object=map(lambda x:x*2+2,[1,2,3,4])
for i in map_object:print(i)

打印结果:

4
6
8
10

map 对list[1,2,3,4] 里的每一个元素,做计算,然后得到一个可迭代对象。map 对象

2.2 处理多个可迭代对象

依次将可迭代对象A第一个元素,与可迭代对象B 第一个元素做处理

可迭代对象A第二个元素,与可迭代对象B 第二个元素做处理

。。。。

最后得到一个新的可迭代对象 map对象

map(lambda x,y: x+y,[1,2,3],[10,20,30])

map_object= map(lambda x,y:x+y,[1,2,3],[10,20,30])
for i in map_object:print(i)

打印结果:

11
22
33

三、reduce

使用reduce ,需要先引入包

from functools import reduce

reduce() 函数语法:

reduce(function, iterable[, initializer])

参数

  • function -- 函数,有两个参数
  • iterable -- 可迭代对象
  • initializer -- 可选,初始参数

作用:

1、 将可迭代对象中的,第一个元素,与第二个元素传入函数做处理,得到的结果作为变量,与第三个元素传入函数再做处理,依次处理

举个例子

累加的例子,list=[1,2,3,4,5]

先处理1+2,得到的结果再与3做相加

from functools import reducelist = [1, 2, 3, 4, 5]def xiangjia(x, y):return x + yif __name__ == '__main__':reduce_object = reduce(xiangjia, list)print(reduce_object)
zip([iterable, ...])

打印结果:

15

四、zip

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

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

zip 语法:

zip([iterable, ...])

参数说明:

  • iterable -- 一个或多个迭代器;

举例 

"abcdef",[1,2,3,4,5],[22,33,44,55] -------->[('a',1,22),('b',2,33),('c','3','44')]

str1 = "abcdef"
list1 = [1,2,3,4,5]
list2 = [22,33,44,55]if __name__ == '__main__':print(zip(str1,list1,list2))
<zip object at 0x7fc5201d8e10>

zip函数,处理,得到一个可迭代对象,zip对象。

使用list ,将zip对象转为list

print(list(zip(str1,list1,list2)))

输出结果:

[('a', 1, 22), ('b', 2, 33), ('c', 3, 44), ('d', 4, 55)]


http://www.ppmy.cn/news/26728.html

相关文章

FPGA 20个例程篇:20.USB2.0/RS232/LAN控制并行DAC输出任意频率正弦波、梯形波、三角波、方波(一)

在最后一个例程中笔者精挑细选了一个较为综合性的项目实战&#xff0c;其中覆盖了很多知识点&#xff0c;也是从一个转产产品中所提炼出来的&#xff0c;所以非常贴近实战项目。 整个工程实现了用户通过对上位机PC端人机界面的操作&#xff0c;即可达到控制豌豆开发并行DAC输出…

基于springboot+vue的校园社团管理系统(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战 主要内容&#xff1a;毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询 文末联系获取 项目介绍…

华为OD机试 - 最差产品奖 | 机试题算法思路 【2023】

最近更新的博客 华为OD机试 - 简易压缩算法(Python) | 机试题算法思路 【2023】 华为OD机试题 - 获取最大软件版本号(JavaScript) 华为OD机试 - 猜字谜(Python) | 机试题+算法思路 【2023】 华为OD机试 - 删除指定目录(Python) | 机试题算法思路 【2023】 华为OD机试 …

第一个Java程序(初识Java)

个人主页&#xff1a;平行线也会相交 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 平行线也会相交 原创 收录于专栏【JavaSE_primary】 文章目录1.Java概述1.1什么是Java1.2Java之父2.0第一个Java程序编译运行.class3.0程序如何跑起来的&#xff1f;3.1J…

【无标题】对象池,大量创建对象时提高性能

在开发中&#xff0c;我们经常会遇到以下场景&#xff1a; 1.对象的大量创建和销毁&#xff0c;比如网口接收数据&#xff0c;进行数据解析。 2.场景中存在大量相同物体的创建和销毁&#xff0c;导致性能下降。 3 循环中大量new对象 看到微软帮助中有一个ConcurrentBag的用法&…

快乐的shell命令行

快乐的shell命令行 PART1——基础 1.权限 #超级用户权限$普通用户 2.复制粘贴 复制&#xff1a;鼠标左键沿着文本拖动高亮的文本被复制到X管理的缓冲区&#xff08;或者双击一个单词&#xff09;粘贴&#xff1a;鼠标中键 3.简单命令 时间和日期date当前月份的日历cal磁…

机器学习:学习k-近邻(KNN)模型建立、使用和评价

机器学习&#xff1a;学习k-近邻&#xff08;KNN&#xff09;模型建立、使用和评价 文章目录机器学习&#xff1a;学习k-近邻&#xff08;KNN&#xff09;模型建立、使用和评价一、实验目的二、实验原理三、实验环境四、实验内容五、实验步骤1.数据读取2.数据理解3.数据准备4.算…

elasticsearch之使用正则表达式自定义分词逻辑

一、Pattern Analyzer简介 elasticsearch在索引和搜索之前都需要对输入的文本进行分词&#xff0c;elasticsearch提供的pattern analyzer使得我们可以通过正则表达式的简单方式来定义分隔符&#xff0c;从而达到自定义分词的处理逻辑&#xff1b; 内置的的pattern analyzer的…