python map函数1分钟数据生成5分钟_一文读懂python的map、reduce函数

这篇文章讲的是Python的map、reduce两大函数。

这对兄弟是出现频率极高且相当实用的python函数,初学者会较难理解,看完本文你就能搞定它们喽!

382f92284e376d393268ab3f9a3302fc.png

01

map

map()方法会将 一个函数 映射到序列的每一个元素上,生成新序列,包含所有函数返回值。

也就是说序列里每一个元素都被当做x变量,放到一个函数f(x)里,其结果是f(x1)、f(x2)、f(x3)......组成的新序列。

d73def42129cebea88105f57af77eef9.png

如何使用map函数?

map(function_to_apply, list_of_inputs)function_to_apply:代表函数

list_of_inputs:代表输入序列

注意:python3中 map函数返回的是迭代器

大多数时候,我们要把列表中所有元素一个个地传递给一个函数,并收集输出。

比方说:

items = [1, 2, 3, 4, 5] # 列表squared = []for i in items:    squared.append(i**2)

map函数可以让我们用一种简单而漂亮得多的方式来实现:

items = [1, 2, 3, 4, 5]squared = list(map(lambda x: x**2, items))

上面使用了匿名函数,也可以自定义函数:

items = [1, 2, 3, 4, 5]def f(x):    return x**2squared = list(map(f, items))

02

reduce

reduce相比map稍复杂点

reduce的工作过程是 :在迭代序列的过程中,首先把 前两个元素(只能两个)传给 函数,函数加工后,然后把 得到的结果和第三个元素作为两个参数传给函数参数, 函数加工后得到的结果又和第四个元素作为两个参数传给函数参数,依次类推。

259e9591a50d8fba08136045efda9f8a.png

reduce函数怎么用?

reduce(function, iterable[, initializer])function:代表函数

iterable:序列

initializer:初始值(可选)与map不同,reduce不可以直接使用,需要用from functools import reduce导入

e946335e7d2a36fc71b7fd5c89a0b3fc.png

比如说我要求10的阶乘,就可以用reduce做:

# 导入reducefrom functools import reduce # 定义函数def f(x,y):    return x*y# 定义序列,含1~10的元素items = range(1,11)# 使用reduce方法result = reduce(f,items)print(result)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值