Python基础-高阶函数-Map-Reduce

Map函数

map()函数接受2个参数
1. 参数 函数
2. 参数 Iterable

示例

#!/usr/bin/env python3
# -*- coding: utf-8 -*-
# map() 函数的使用

# 转换为字符串
def funtion(x):
    return str(x)

def test():

    mList = [1,2,3,4,5]
    # ('List ', [1, 2, 3, 4, 5])
    print("List ", mList)

    # Map函数的使用:函数, Iterator
    # ('Map ', ['1', '2', '3', '4', '5'])
    mMap = map(funtion, [1,2,3,4,5])
    print("Map ", mMap)

# 运行测试程序    
test()

运行结果

D:\PythonProject>python run.py
('List ', [1, 2, 3, 4, 5])
('Map ', ['1', '2', '3', '4', '5'])

我的理解是,管他的能用就行,知道怎么传参,传出什么结果就行了。结果是以一个新的Iterator,项目用到的时候才是关键

Reduce用法

reduce把一个函数作用在一个序列[a,b..]上,这个函数必须接受2个参数,reduce把结果继续和序列的下一个元素做累积计算,效果如下

reduce(f(x, y), [a, b]) = f(a, b)

我的理解就是传递2个类似递归函数的,详见下面demo,看代码理解得快

实例

#!/usr/bin/env python3
# -*- coding: utf-8 -*-
# Python Reduce用法

# reduce(f(x, y), [a, b]) = f(a, b)
# reduce(f(x, y), [a, b, c]) = f(f(a, b),c)

# 2 个参数的函数
def function(x, y):
    return x +y

def reduceTest():
    # reduce(f(x, y), [a, b]) = f(a, b)
    # f(x, y) = f(1, 2) = 1 + 2 = 3
    # 预测值 result = 3
    result = reduce(function, [1, 2])
    # 实际答案 3
    print(result)

    # reduce(f(x, y), [a, b, c]) = f(f(a, b),c)
    # 第一步f(x, y) = f(1, 2) = 1 + 2 = 3
    # 第二步f(x, y) = f(3, 3) = 1 + 2 = 6
    result = reduce(function, [1, 2,3])
    # 实际答案 6
    print(result)

reduceTest()

运行结果

D:\PythonProject>python run.py
3
6
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

法迪

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

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

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

打赏作者

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

抵扣说明:

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

余额充值