python中的map reduce ,filter=[][=======]

本文详细介绍了map、reduce、filter三个函数。map函数根据提供的函数对指定序列做映射,输出和输入shape相同;reduce函数对参数序列中元素进行累计,输出为输入的合并,shape变化;filter函数用于过滤序列,输出可能和输入shape不同。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. map-拆分为子任务,----->对每个元素采用相同的操作,输出和输入shape相同
  2. reduce-合并---->对所有的元素同时执行某个操作,输出为输入的合并,shape变化
  3. filter-过滤------>对数据筛选,输出可能和输入shape不同

1. map:

map() 会根据提供的函数对指定序列做映射.

  • 第一个参数( function): 以参数序列中的每一个元素调用 function 函数,返回包含每次 function 函数返回值的新列表.
  • 第二个参数:需要处理的序列
#首字母大写:
my_list = ['smith', 'edward', 'john', 'obama', 'tom']


def f(x):
    return x[0].upper() + x[1:]


result = map(f, my_list)
print(list(result))

输出结果:

['Smith', 'Edward', 'John', 'Obama', 'Tom']

 

2. reduce:

reduce() 函数会对参数序列中元素进行累计.

函数将一个数据集合中的所有数据进行下列操作:

  1. 用 function(有两个参数)先对集合中的第 1、2 个元素进行操作.
  2. 将得到的结果  与  第三个参数   用 function 函数运算, 最后得到一个结果
# 计算列表中的累加和:

import functools

my_list = [1, 2, 3, 4, 5]


def f(x1,x2):
    return x1 + x2


result = functools.reduce(f, my_list)#此处注意需要导入functools工具
print(result)

输出结果:

15

 

3.filter:

 filter() 函数用于过滤序列, 过滤掉不符合条件的元素, 返回一个 filter 对象, 如果要转换为列表, 可以使用 list() 来转换.

该接收两个参数, 第一个为函数, 第二个为序列, 序列的每个元素作为参数传递给函数进行判, 然后返回 True 或 False, 最后将返回 True 的元素放到新列表中.

a = [2, 4, 6, 8, 11]


def f(x):
    if x % 2 == 0:
        return True


if __name__ == '__main__':
    result = filter(f, a)
    print(list(result))#此处得用list转换下
# 15

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

贾世林jiashilin

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值