map()、reduce()、filter()、zip()

map()

内置函数map()把一个函数func依次映射到序列或迭代器对象的每个元素上,并返回一个可迭代的map对象作为结果,map对象中每个元素是原序列中元素经过函数func处理后的结果

map(func, *iterables) --> map object

>>> map(str,range(5))
<map object at 0x036466D0>
>>> list(_)
['0', '1', '2', '3', '4']

>>> def add5(v):
	return v+5
>>> list(map(add5 , range(5)))
[5, 6, 7, 8, 9]

>>> list(map(lambda x: x % 2, range(7)))
[0, 1, 0, 1, 0, 1, 0]

reduce()

标准库functools 中的函数reduce()
reduce(function, sequence[, initial]) -> value

reduce(lambda x, y: x+y, [1, 2, 3, 4, 5])
calculates ((((1+2)+3)+4)+5)

>>> reduce(lambda x, y:x+y , list(range(10)))
45

filter()

filter(function or None, iterable) --> filter object

  1. 用于过滤序列,过滤掉不符合条件的元素,返回由符合条件元素组成的新列表。
  2. 该函数接收两个参数,第一个为函数,第二个为序列,序列的每个元素作为参数传递给函数进行判断,然后返回 True 或 False,最后将返回True 的元素放到新列表中。
  3. 注意:Python2.7返回的是列表,Python3.x返回的是迭代器对象。
>>>newlist = list(filter(lambda n:n%2==1,[1,2,3,4,5,6,7,8,9,10]))
>>>print(newlist)
[1, 3, 5, 7, 9]

zip()

zip(*iterables) --> zip object

>>> list(zip('asdf','123'))
[('a', '1'), ('s', '2'), ('d', '3')]

>>> list(zip('asdf','123','...!'))
[('a', '1', '.'), ('s', '2', '.'), ('d', '3', '.')]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值