引入

python内置了很多可以供我们直接调用的函数,这些函数的效率往往都非常高。我们在自己造轮子的同时,也非常有必要了解并且正确使用python给我们提供的大量的内置函数。在前面的博客里面我已经介绍了collections模块里面的几个比较常用的函数,这里再介绍几个。

1.enumerate

 enumerate(iterable, start=0) :对指定的对象进行枚举

返回一个枚举对象。 iterable 必须是一个序列,或  iterator ,或其他支持迭代的对象。 enumerate() 返回的迭代器的 __next__() 方法返回一个元组,里面包含一个计数值(从 start 开始,默认为 0)和通过迭代 iterable 获得的值。

注: iterable 指的是可迭代对象, iterator 指的是迭代器,需要注意的是可迭代对象不一定是迭代器,而迭代器一定是可迭代对象,迭代器需要实现 __next__() 方法。

例:

names = ['zhangsan', 'lisi', 'wangwu']

print(list(enumerate(names)))
# [(0, 'zhangsan'), (1, 'lisi'), (2, 'wangwu')] print(list(enumerate(names, start=1)))
# [(1, 'zhangsan'), (2, 'lisi'), (3, 'wangwu')]

相当于:

def enumerate(sequence, start=0):
n = start
for elem in sequence:
yield n, elem
n += 1

2.map

 map(function, iterable, ...) : 作用是将一个列表映射到另一个列表

对参数 iterable 中每个元素都调用funcion(函数),并返回输出其结果的迭代器。 如果传入了额外的 iterable 参数,function必须接受相同个数的实参。 当有多个可迭代对象时,最短的可迭代对象耗尽则整个迭代就将结束。

例1:

print(list(map(lambda x:x+1,[1,2,3])))
# [2, 3, 4]

注意:因为返回的是可迭代对象,所以需要调用list来显示。

例2:

def add(n, m):
return n + m lst = list(map(add, [1, 2, 3], [1, 2, 3]))
print(lst) # [2, 4, 6]

例3:

# map(x, y) 返回x的y次幂
lst = map(pow, [1, 2, 3], [1, 2, 3])
print(list(lst)) # [1, 4, 27]

3.filter

 filter(function, iterable) :对指定序列执行过滤操作

filter函数会对序列参数 iterable 中的每个元素调用function函数,最后返回的结果包含调用结果为True的元素。

返回一个迭代器,需要用list调用来显示所有结果。

例1:

print(list(filter((lambda x: x>0), range(-5, 5))))
# [1, 2, 3, 4]

例2:

print(list(fliter(None, range(-2, 2))))
# [-2, -1, 1]

例3:

def func(x):
# 返回同时不能被2和3整除的元素
return x % 2 != 0 and x % 3 != 0 print(list(filter(func, range(2,25))))
# [5, 7, 11, 13, 17, 19, 23]

4.zip

 zip(*iterables) :用来创建一个聚合了每个可迭代对象中的元素的迭代器。

接受一系列可迭代对象作为参数,将对象中对应的元素打包成一个个tuple,然后返回由这些tuples组成的迭代器。若传入参数的长度不相等,以长度最短的可迭代对象为准。

例1:

print(list(zip([1, 2, 3], [4, 5, 6])))
# [(1, 4), (2, 5), (3, 6)]

例2:

print(list(zip([1, 2, 3], [4, 5, 6, 7], [8, 9, 10, 11, 12])))
# [(1, 4, 8), (2, 5, 9), (3, 6, 10)]

应用一:矩阵变换

"""
初始:
1 2 3
4 5 6
7 8 9
变换:
1 4 7
2 5 8
3 6 9
""" matrix = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
print([[row[col] for row in matrix] for col in range(len(matrix[0]))]) # 行变列
# [[1, 4, 7], [2, 5, 8], [3, 6, 9]] print(list(zip(*matrix)))
# [(1, 4, 7), (2, 5, 8), (3, 6, 9)] print(list(map(list, zip(*matrix))))
# [[1 ,4 ,7], [2, 5, 8], [3, 6, 9]]

应用二:*操作符与zip函数配合可以实现与zip相反的功能,即将合并的序列拆成多个tuple

x=[1,2,3]
y=['a','b','c']
print(list(zip(*zip(x,y))))
# [(1,2,3),('a','b','c')]

应用三:使用zip合并相邻的列表项

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

print(list(zip(*([iter(a)] * 2))))
# [(1, 2), (3, 4), (5, 6)] group_adjacent = lambda a, k: zip(*([iter(a)] * k))
print(list(group_adjacent(a, 3)))
# [(1, 2, 3), (4, 5, 6)] print(list(group_adjacent(a, 2)))
# [(1, 2), (3, 4), (5, 6)] print(list(group_adjacent(a, 1)))
# [(1,), (2,), (3,), (4,), (5,), (6,)] print(list(zip(a[::2], a[1::2])))
# [(1, 2), (3, 4), (5, 6)] print(list(zip(a[::3], a[1::3], a[2::3])))
# [(1, 2, 3), (4, 5, 6)] group_adjacent = lambda a, k: zip(*(a[i::k] for i in range(k)))
print(list(group_adjacent(a, 3)))
# [(1, 2, 3), (4, 5, 6)] print(list(group_adjacent(a, 2)))
# [(1, 2), (3, 4), (5, 6)]

应用四:使用zip和iterators生成滑动窗口 (n -grams)

from itertools import islice

#  islice(iterable, [start, ] stop [, step]),将跳过前start个项,迭代在stop所指定的位置停止,step指定用于跳过项的步幅。
def n_grams(a, n):
z = (islice(a, i, None) for i in range(n)) #当n为3时z可以看作:((1, 2, 3, 4, 5, 6), (2, 3, 4, 5, 6), (3, 4, 5, 6))
return zip(*z) a = [1, 2, 3, 4, 5, 6]
print(list(n_grams(a, 3)))
#[(1, 2, 3), (2, 3, 4), (3, 4, 5), (4, 5, 6)] print(list(n_grams(a, 2)))
#[(1, 2), (2, 3), (3, 4), (4, 5), (5, 6)] print(list(n_grams(a, 4)))
#[(1, 2, 3, 4), (2, 3, 4, 5), (3, 4, 5, 6)]

应用五:使用zip反转字典

m = {'a': 1, 'b': 2, 'c': 3, 'd': 4}
print(list(m.items()))
#[('a', 1), ('c', 3), ('b', 2), ('d', 4)] print(list(zip(m.values(), m.keys())))
#[(1, 'a'), (3, 'c'), (2, 'b'), (4, 'd')] print(dict(zip(m.values(), m.keys())))
#{1: 'a', 2: 'b', 3: 'c', 4: 'd'}

~>.<~

python中的enumerate、map、filter和zip函数的更多相关文章

  1. Python面试题之Python中的lambda map filter reduce zip

    当年龟叔想把上面列出来的这些都干掉.在 “All Things Pythonic: The fate of reduce() in Python 3000”这篇文章中,他给出了自己要移除lambda. ...

  2. python常用函数进阶(2)之map,filter,reduce,zip

    Basic Python : Map, Filter, Reduce, Zip 1-Map() 1.1 Syntax # fun : a function applying to the iterab ...

  3. 揭秘 Python 中的 enumerate() 函数

    原文:https://mp.weixin.qq.com/s/Jm7YiCA20RDSTrF4dHeykQ 如何以去写以及为什么你应该使用Python中的内置枚举函数来编写更干净更加Pythonic的循 ...

  4. [转]关于python中带下划线的变量和函数的意义

    Python 的代码风格由 PEP 8 描述.这个文档描述了 Python 编程风格的方方面面.在遵守这个文档的条件下,不同程序员编写的 Python 代码可以保持最大程度的相似风格.这样就易于阅读, ...

  5. Python中字符串String的基本内置函数与过滤字符模块函数的基本用法

    Python中字符串String的基本内置函数与用法 首先我们要明白在python中当字符编码为:UTF-8时,中文在字符串中的占位为3个字节,其余字符为一个字节 下面就直接介绍几种python中字符 ...

  6. 关于Python中的类普通继承与super函数继承

    关于Python中的类普通继承与super函数继承 1.super只能用于新式类 2.多重继承super可以保公共父类仅被执行一次 一.首先看下普通继承的写法 二.再看看super继承的写法 参考链接 ...

  7. python中lambda以及与filter/map/reduce结合的用法

    一.lambda函数即匿名函数,和普通的函数相比,就是省去了函数名称而已: lambda语句中,冒号前是参数,可以有多个,用逗号隔开,冒号右边是函数体的返回值 g = lambda x,y : x+y ...

  8. 2018.8.15 python 中的sorted()、filter()、map()函数

    主要内容: 1.lambda匿名函数 2.sorted() 3.filter() 4.map() 5.递归函数 一. lambda匿名函数 为了解决一些简单的需求而设计的一句话函数 # 计算n的n次方 ...

  9. Python中的enumerate函数的作用

    enumerate函数是将一个可迭代对象中元素,按元素顺序每个增加一个索引值,将其组成一个索引序列,利用它可以同时获得索引和值,这样做的目的是为了将一个可迭代对象中元素组成一个"索引,值&q ...

随机推荐

  1. 06Redis入门指南笔记(安全、通信协议、管理工具)

    一:安全 1:可信的环境 Redis以简洁为美.在安全层面Redis也没有做太多的工作.Redis的安全设计是在"Redis运行在可信环境"这个前提下做出的.在生产环境运行时不能允 ...

  2. hdu 3873 Invade the Mars(有限制的最短路 spfa+容器)

    Invade the Mars Time Limit: 5000/2000 MS (Java/Others)    Memory Limit: 365768/165536 K (Java/Others ...

  3. AtCoder Beginner Contest 077 D Small Multiple(最短路)

    水过前三道题之后,一直在写这个题,做不对.总有那么几组数据过不去... 看了看题解是最短路,这思路感觉很神奇.看了下唯一做出来这题的那人的代码,是搜索做的. 标程: 对每个数字x,向x+1建一条花费为 ...

  4. Ext.FormPanel-----FieldSet的用法

    Ext.form.FieldSet的常用配置项: 1.checkboxToggle : Mixed True表示在lengend标签之前fieldset的范围内渲染一个checkbox,或者送入一个D ...

  5. hsqldb使用

    1 hsqldb介绍 HyperSQL DataBase 是一个现代的关系数据库管理软件,比较彻底遵从SQL:2008标准和JDBC4规范.支持SQL:2008标准所以的核心特性和很多的可选特性. H ...

  6. 洛谷P1595 信封问题 题解 错排问题

    作者:zifeiy 标签:排列组合,错排问题 题目链接:https://www.luogu.org/problem/P1595 题目描述:某人写了n封信和n个信封,如果所有的信都装错了信封.求所有信都 ...

  7. java TreeSet的排序之自然排序

    TreeSet会调用元素的compareTo(Object o)方法来比较元素之间的大小关系,然后将集合里的元素按升序排列.此时需要排序元素的类必须实现Compareble接口,并覆写其int com ...

  8. Vue 项目构建完成 ----发布项目

    发布项目 cmd  命令行 npm run build      执行打包文件 完成后就会有  3 个文件夹    分别是: 文件夹 :build     config      dist    in ...

  9. java 递归(Recursion)

    现在要求输出一个给定目录中的全部文件的路径. 本程序肯定只能依靠递归的操作完成,因为在一个给定的路径下有可能还是文件夹,那么如果是文件夹的话则肯定要继续列出,重复判断. 递归:程序调用自身的编程技巧 ...

  10. Javascript 防扒站,防止镜像网站

    自己没日没夜敲出来的站,稍微漂亮一点,被人看上了就难逃一扒,扒站是难免的,但不能让他轻轻松松就扒了: 前些天有个朋友做的官网被某不法网站镜像,严重影响到 SEO,当时的解决方法是通过屏蔽目标 IP 来 ...