一, 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