博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
谈谈python里面那些高级函数
阅读量:4227 次
发布时间:2019-05-26

本文共 3162 字,大约阅读时间需要 10 分钟。

谈到python,我们就不得不说python里面的一些黑魔法,例如我们的高阶函数就是黑魔法其中之一。

640?wx_fmt=png

高阶函数是什么?

简而言之就是将一个函数作为参数传到另一个函数A中,那么这个函数A就是高阶函数。(可接收其他函数作为参数的函数称为高阶函数)

我们来看一个简单的小例子:

def func(a, list): return [a(x) for x in list] def double(x): return 2 * x print(func(double, [1, 3, 5, 7]))

640?wx_fmt=png

上面的代码中,func 是一个高阶函数,它接收两个参数,第 1 个参数是函数,也就是我们定义的double函数,第 2 个参数是list,func 的功能是将函数 a 逐个作用于list上,生成一个新的数组。 

我们在使用func函数的时候传入的第一个参数是函数的名字,不需要括号和其他的东西,只传函数名即可。

下面我们来看看,python自带了一些高阶函数,他们分别是map,reduce,filter。除此之外还有一个很特别的函数叫匿名函数lambda。

在了解内置高阶函数之前,我们先来看看lambda是个怎么样的东西。

就拿我们刚刚定义的double函数来说,它的功能是将传入的参数整体乘2,对于这么简单的功能,我们可能都不需要用def来定义函数,这个时候我们使用lambda来快捷定义函数即可:

double = lambda x: 2 * x print(double(3))

640?wx_fmt=png

代码形式:

lambda 参数: 表达式

主要看来其实就是定义的时候换了一种方式,类似于定义一个表达式这样,可以对这个表达式直接进行赋值。调用的时候还是一样,函数的名字就是赋值的变量名。

当然,我们也可以在定义的时候直接调用,也能运算结果:

print((lambda x: 2 * x)(3))

640?wx_fmt=png

lambda定义与使用如此方便就决定了它的使用场景会特别的多,一般的:当我们需要创建一些临时的、小巧的函数时,就会使用lambda了。一般的,当我们使用高阶函数的时候会经常和lambda函数一起联用。

对于上面的高阶函数我们可以使用lambda改写:

a = func(lambda x: 2 * x, [1, 3, 5, 7]) print(a)

Tips:

  • 匿名函数本质上是一个函数,没有函数名称,因此使用匿名函数不用担心函数名冲突;

  • 匿名函数一般适用于创建一些临时性的,小巧的函数;

map函数

下面我们来看看MAP函数:

map函数的使用形式如下:

map(function, sequence)

function就是传入的函数名,sequence就是需要被function函数处理元素组成的序列。 整个过程可以理解成如下:

sequence = [item1, item2, item3, item4, item5] for i in sequence:     function(i)

我们来看看几个例子:

map(lambda x: x**2, [1, 2, 3])

640?wx_fmt=png

这是一个map对象(迭代器),我们可以通过将它结果输出:

for i in map(lambda x: x**2, [1, 2, 3]): print(i)

640?wx_fmt=png

当然,我们也可以将map的结果直接转化成list:

list(map(lambda x: x**2, [1, 2, 3]))

reduce函数

python3版本的reduce函数已经不再是内置函数了,它需要在functools模块中导入:

from functools import reduce

reduce函数的使用形式如下:

reduce(function, sequence[, initial])

先将 sequence 的前两个 item 传给 function,即 function(item1, item2),函数的返回值和 sequence 的下一个 item 再传给 function,即 function(function(item1, item2), item3),如此迭代,直到 sequence 没有元素,如果有 initial,则作为初始值调用。

reduece(f, [x1, x2, x3, x4]) = f(f(f(x1, x2), x3), x4)
a = reduce(lambda x, y: x*y, [1, 2, 3, 4, 5, 6]) print(a)

有一点需要注意的是reduce的传入函数需要传入两个参数,例如上面的例子:我们先选取list中的前两个元素进行lambda函数相乘,然后将相乘的结果再与第三个元素相乘,如此继续下去,一直到整个list元素都被读取为止。

reduce(lambda x, y: x * y, [1, 2, 3, 4])  # 相当于 ((1 * 2) * 3) * 4 reduce(lambda x, y: x * y, [1, 2, 3, 4], 5) # ((((5 * 1) * 2) * 3)) * 4 reduce(lambda x, y: x / y, [2, 3, 4], 72)  #  (((72 / 2) / 3)) / 4 reduce(lambda x, y: x + y, [1, 2, 3, 4], 5)  # ((((5 + 1) + 2) + 3)) + 4 reduce(lambda x, y: x - y, [8, 5, 1], 20)  # ((20 - 8) - 5) - 1 f = lambda a, b: a if (a > b) else b   # 两两比较,取最大值 reduce(f, [5, 8, 1, 10])

filter函数

filter 函数用于过滤元素,它的使用形式如下:

filter(function, sequnce)

解释:将 function 依次作用于 sequnce 的每个 item,即 function(item),将返回值为 True 的 item 组成一个 List/String/Tuple (取决于 sequnce 的类型,python3 统一返回迭代器, 和map一样) 返回。

其实简单来说filter就是一个过滤器,筛选sequnce里面有用的元素。整个过程类似如下:

sequence = [item1, item2, item3, item4, item5] sequence2 = [] for i in sequence: if function(i)==True:         sequence2.append(i) print(sequence2)

我们来看一个例子:

def odd(x): return x % 2 number = filter(odd,range(10)) print(number)             
number = list(filter(odd,range(10))) print(number)             [1, 3, 5, 7, 9]

换成lambda:

number = list(filter(lambda x: x%2,range(10))) print(number)             [1, 3, 5, 7, 9]

以上就是我们在python3中常用也不常用的高阶函数了,他们为函数式编程提供了不少便利,可使代码变得更简洁,如果有需要用到的地方大家以后可以尽量去使用哦!

640?wx_fmt=gif

“扫一扫,走遍天下都不怕”

转载地址:http://wenqi.baihongyu.com/

你可能感兴趣的文章
关于#include "stdafx.h"
查看>>
VC下线程同步的三种方法(互斥、事件、临界区)/(转)
查看>>
非常好的一篇U-BOOT的文章--转载
查看>>
【设计模式】学习之创建型 单例模式
查看>>
【设计模式】学习之创建型 原型模式
查看>>
【设计模式】学习之结构型 适配器模式-装饰器模式-代理模式
查看>>
Maven+Eclipse+Tomcat+Spring MVC web 请求 404 问题总结及noHandlerFound
查看>>
SpringMVC API缓存 LastModified的实现总结
查看>>
406 Not Acceptable 415 Unsupported Media Type Spring MVC consumes与produces
查看>>
MyBatis 高级映射与懒加载
查看>>
HCIP-H12-222练习题
查看>>
点到点IPSec VPN的配置
查看>>
MySQL InnoDB何时更新表的索引统计信息
查看>>
MTU 设置错误导致防火墙或者路由器断网
查看>>
子网划分详解与子网划分实例
查看>>
游戏通讯技术:帧同步技术
查看>>
防火墙技术指标---并发连接数/吞吐量
查看>>
V100服务器和T4服务器的性能指标
查看>>
elasticsearch 启动、停止及更改密码
查看>>
Kafka,它为什么速度会这么快?
查看>>