python中的四个BIF:filter()、map()、zip()、enumerate()

2024-03-26 15:58

本文主要是介绍python中的四个BIF:filter()、map()、zip()、enumerate(),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一,filter()

过滤器

先来看下Python自己的注释如下:

help(filter)class filter(object)|  filter(function or None, iterable) --> filter object|  |  Return an iterator yielding those items of iterable for which function(item)|  is true. If function is None, return the items that are true.
...

大概意思是:filter有两个参数。第一个参数可以是一个参数也可以是None,如果是一个函数的话,则将第二个可迭代数据里的每一个元素作为函数的参数进行计算,把返回的True的值筛选出来;如果第一个参数为None,则直接将第二个参数中为True的值筛选出来。
实例如下:

temp = filter(None,[200,-9,0,True,False])
print(list(temp),type(temp))
#-----output-------------------------
[200, -9, True] <class 'filter'>
# 尝试写一个筛选基数的过滤器:
def odd(x):return x % 2temp = filter(odd,range(10))
print(list(temp),type(list))# 如果使用 lambda 函数来操作,效果如下:
list(filter(lambda x :x%2,range(10)))#-----output--------------------------
[1, 3, 5, 7, 9] <class 'type'>

二,map()

映射

map()找个内置函数也有两个参数,仍然是一个参数和一个可迭代序列,将序列的每一个元素作为函数的参数进行运算加工,直到可迭代序列每个元素都加工完毕,返回所有加工后的元素构成的新序列。

list(map(lambda x :x*2),range(10))

三,zip()

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

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

a = [1,2,3]
b = [4,5,6]
c = [7,8,9,10,11]zipped = zip(a,b) 
zipped_list = list(zipped)
print(zipped,zipped_list)zipped = zip(a,c) 
zipped_list = list(zipped)
print(zipped,zipped_list)#-----output--------------------------
<zip object at 0x7f76f101c388> [(1, 4), (2, 5), (3, 6)]
<zip object at 0x7f76f101b688> [(1, 7), (2, 8), (3, 9)]

四,enumerate()

枚举

enumerate()方法生成由二元组(二元组就是元素数量为二的元组)构成的一个迭代对象,每个二元组是由可迭代参数的索引号以及对应的元素组成的。

str1 = "nihui"
for each in enumerate(str1):print(each)#-----output--------------------------
(0, 'n')
(1, 'i')
(2, 'h')
(3, 'u')
(4, 'i')

五,lambda表达式

Python 允许使用 lambda 关键字来创建匿名函数。
具体实例如下:

# 正常函数定义如下: 
def ds(x):return 2 * x + 1 res = ds(5)# lambada 定义如下: 
ds = lambda x : 2 * x + 1 
res = ds(5)

这篇关于python中的四个BIF:filter()、map()、zip()、enumerate()的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/849040

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

Python安装时常见报错以及解决方案

《Python安装时常见报错以及解决方案》:本文主要介绍在安装Python、配置环境变量、使用pip以及运行Python脚本时常见的错误及其解决方案,文中介绍的非常详细,需要的朋友可以参考下... 目录一、安装 python 时常见报错及解决方案(一)安装包下载失败(二)权限不足二、配置环境变量时常见报错及

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(