python的 map,filter, reduce, enumerate
一, map #基本的map运用都可以用解析去替代,复杂的仍然需要定义函数,利用map去做
map(函数, 序列) 将序列的各项经过函数处理, 然后返回到一个新列表中。 #itertools.imap()
>>> s
['a', 'b', 'c', 'd']
>>> exp1 = map(ord, s) #s 也可以是字符串, 元组, 字典
>>> exp1
[97, 98, 99, 100]
序列的个数根据前面的函数而定, ord()一次接受一个,所以后面只有一个序列。
>>> add = lambda x, y: x+y
>>> map(add, {'a':'djsfld', 'b': 'dgfasg'}, 'fg') #自定义了一个add函数,接受两个参数,所以后面是两个可迭代的对象。
['af', 'bg']
注意,后面的两个对象长度必须一致, map不具有不短和截长的功能。
而zip会将长的多余部分给截去, 如:
>>> zip( {'a':'djsfld', 'b': 'dgfasg'}, 'fgf')
[('a', 'f'), ('b', 'g')] #可以一次循环多个对象,itertools.izip()
在python3* 中,返回的不是列表,而是可迭代对象,可以通过list()函数得到以上结果。
>>> def xixi(x,y):
... if x>y: return x+y
... else: return y
...
>>> map(xixi, 'abcdefg', ['e','a','c','b','f','t','j'])
['e', 'ba', 'c', 'db', 'f', 't', 'j']
二, filter #基本的filter运用都可以用解析去替代, 复杂的仍然要自定义函数,利用filter去做,这也许是map和filter依然存在的原因。
filter(过滤函数, 列表) 将列表中的元素经过函数,如果返回True, 就放到一个新的列表中,如果返回False, 就不放进去。#itertools.dropwhile
filter只能一次处理一个元素。所以后面只有一个序列。
>>> def hehe(x):
... if ord(x)>100:return True
... else: return False
...
>>> filter(hehe, 'av')
'v'
>>> filter((lambda x:x>0), range(-5,5))
[1, 2, 3, 4]
在python3*中返回的不直接是列表,而是一个迭代器。可以用list()查看结果。
三, reduce
对每队元素都应用函数并运行到最后结果。
>>> reduce((lambda x, y: x+y),range(-5,5))
-5
算法是这样的:(((((((((-5+-4)+-3)+ -2)+ -1)+ 0)+ 1)+ 2)+ 3)+ 4) = -5
四, enumerate
s='SAASDFASDF\n'
>>> for i,j in enumerate(s.strip()): 同时返回这个元素以及元素的index
... print i,j
...
0 S
1 A
2 A
3 S
4 D
5 F
6 A
7 S
8 D
9 F
注意:返回的index是整型!!!!!!!!
by freemao
FAFU
free_mao@qq.com
python的 map,filter, reduce, enumerate的更多相关文章
- Python map filter reduce enumerate zip 的用法
map map(func, list) 把list中的数字,一个一个运用到func中,常和lambda一起用. nums = [1, 2, 3, 4, 5] [*map(lambda x: x**2, ...
- Python中map,filter,reduce,zip的应用
事例1: l=[('main', 'router_115.236.xx.xx', [{'abc': 1}, {'dfg': 1}]), ('main', 'router_183.61.xx.xx', ...
- Python【map、reduce、filter】内置函数使用说明(转载)
转自:http://www.blogjava.net/vagasnail/articles/301140.html?opt=admin 介绍下Python 中 map,reduce,和filter 内 ...
- 【转】Python 中map、reduce、filter函数
转自:http://www.blogjava.net/vagasnail/articles/301140.html?opt=admin 介绍下Python 中 map,reduce,和filter 内 ...
- python常用函数进阶(2)之map,filter,reduce,zip
Basic Python : Map, Filter, Reduce, Zip 1-Map() 1.1 Syntax # fun : a function applying to the iterab ...
- Python【map、reduce、filter】内置函数使用说明
题记 介绍下Python 中 map,reduce,和filter 内置函数的方法 一:map map(...) map(function, sequence[, sequence, ...]) -& ...
- python 内置函数 map filter reduce lambda
map(函数名,可遍历迭代的对象) # 列组元素全加 10 # map(需要做什么的函数,遍历迭代对象)函数 map()遍历序列得到一个列表,列表的序号和个数和原来一样 l = [2,3,4,5,6, ...
- 如何在python3.3用 map filter reduce
在3.3里,如果直接使用map(), filter(), reduce(), 会出现 >>> def f(x): return x % 2 != 0 and x % 3 != 0 ...
- Swift map filter reduce 使用指南
转载:https://useyourloaf.com/blog/swift-guide-to-map-filter-reduce/ Using map, filter or reduce to ope ...
- 数组的高阶方法map filter reduce的使用
数组中常用的高阶方法: foreach map filter reduce some every 在这些方法中都是对数组中每一个元素进行遍历操作,只有foreach是没有 ...
随机推荐
- linux系统设置静态IP 查看网卡配置文件
http://jingyan.baidu.com/article/455a99508be7cda167277865.html vi /etc/sysconfig/network-scripts/ifc ...
- office 使用技巧
Excel: 非打印区域显示成灰色:视图--分页预览 选定行的时侯,如何从某一行选定到末尾? 先点某一行,然后按住shift不松,再按END,再按下方向箭. 选定列也是这样,先按住某列,然后按SHIF ...
- Storm实时流处理Hello World
近来在看Storm的相关资料,以下总结一下配置过程和Hello World例子. Storm是分布式的实时计算系统.详细文档可参考Storm网站,也可以参阅<Getting started wi ...
- 在 CentOS 7 中安装并使用自动化工具 Ansible
Ansible是一款为类Unix系统开发的自由开源的配置和自动化工具.它用Python写成,类似于Chef和Puppet,但是有一个不同和优点是我们不需要在节点中安装任何客户端.它使用SSH来和节点进 ...
- 过滤器 Filter
Filter(过滤器)简介 Filter 的基本功能是对发送到 Servlet 的请求进行拦截, 并对响应也进行拦截. Filter 程序是一个实现了 Filter 接口的 Java 类,与 Serv ...
- 【C语言学习】-03 循环结构
本文目录 循环结构的特点 while循环 do...while循环 for循环 回到顶部 一.循环结构的特点 程序的三种结构: 顺序结构:顺序执行语句 分支结构:通过进行一个判断在两个可选的语句序列之 ...
- 基于K2 BPM平台,中原地产实现了从2个人到5万多人的跨越
演讲人:吴付文 中原地产CIO 点击这里查看中原地产怎么使用BPM实现业绩的飞跃式发展.
- 自定义cursor
cursor: url('绝对路径/big.cur'),auto; //通用方式
- wsgi协议
用来为server程序和app/framework程序做连接桥梁的,使server和app/framework各自发展,任意组合 上图是python3.4标准库里面,关于wsgiserver的实现.从 ...
- NABCD分析
NABCD——今日事 N(Need):开创的成就系统可以在一定程度上督促用户坚持下来. A(Approach):做一个APP软件,是在android平台构建. B(Benefit):可以逐步改变用户的 ...