点击上方蓝色文字关注我们吧

有你想要的精彩

作者 | 那个百分十先生出品 | Python知识学堂

上次推文我们介绍了python中的《Logging日志模块》的相关知识,这次推文我们将学习一下python中的高阶函数等相关的知识,这些高阶函数我们是非常常见的,比如我们经常使用的Map、Filter、Reduce。

定义

在学习python的基础知识的时候,我们可能会学到一个概念“函数式编程”,我们来看看百度百科的介绍:

"函数式编程"是一种"编程范式"(programming paradigm),也就是如何编写程序的方法论。它属于"结构化编程"的一种,主要思想是把运算过程尽量写成一系列嵌套的函数调用。

也就是说函数式编程有这样的特点:

  • 函数可作为对象可以赋值给变量。

  • 函数可作为参数传递给另一个函数。

  • 函数可作为一个参数返回。

那么高阶函数的定义是什么呢?简单的来说,只要满足一下的条件就可以认为这个函数是高阶函数:

  • 函数可以作为参数传给另外一个函数;

  • 函数的返回值为另外一个函数;

当然了,若一个函数的返回值为该函数本身的话,很显然就这就是我们常见的递归。

我们来看看几个简单的例子:

# 例1 函数作为参数传给另外一个函数def print_1():   print("打印1")def print_2(print_1):   # 调用print_1()函数   print_1()   print("打印2")   print("打印结束")# 函数调用,参数为print_1()函数print_2(print_1)
#例2#返回值为一个函数def print_1():   print("我爱python")def print_2():   print("我爱python知识学堂")# 返回值为一个函数return(print_1())# 函数调用print_2()

Map

Map()是python内置函数,它会根据所传递的函数对指定的序列(可迭代)做映射,原型如下:

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

参数function:是一个函数,是自定义或者python内置的函数都可以。

参数*iterable:是可迭代的对象,比如我们常用的列表,元组等。

返回值map object:表示map函数的返回值是一个map对象。

简单的来说这个Map函数的功能就是使用func对传入的iterable的每一个元素(比如列表的每一个元素)进行处理,返回对象如

注意到参数iterable是加了符号“*”的,所以说这个参数的意思是可以接受多个可迭代的对象的。接下来我们看几个例子:

Function为内置函数

string_1 = 'Python知识学堂'           #字符串string_2 = [1,2,3,4,5,6]             #列表string_3 = {'python':2,'学习':3,1:4}  #字典res1 = map(str,string_1)res2 = map(str,string_2)res3 = map(str,string_3)print(string_1)print(list(res1))print(list(res2))print(list(res3))

上述例子使用python的内置函数str()将字符串和列表的每个元素变成了str类型,根据map函数的说明我们知道res1和res2是一个Iterator,Iterator是惰性可迭代序列,因此通过list()函数将值求出来,注意,map不改变原list。

关于迭代器的惰性计算,这里先引用网上的一句话:

“迭代器的一个优点就是它不要求你事先准备好整个迭代过程中所有的元素。迭代器仅仅在迭代至某个元素时才计算该元素,而在这之前或之后,元素可以不存在或者被销毁。这个特点使得它特别适合用于遍历一些巨大的或是无限的集合,比如几个G的文件,或是斐波那契数列等等。这个特点被称为延迟计算或惰性求值(Lazy evaluation)。”

Function为自定义函数

上述使用的是python的内置函数str(),实际的项目中我们更多的是传入自定义的函数:

def self_test(x):return x + 2string = [1,2,3,4,5,6]res = map(self_test, string)print(list(res))#输出 [3, 4, 5, 6, 7, 8]

上述代码中 向map函数中传入了自定义的self_test函数,函数加对传入的元素加2的处理,理解起来还是很简单的。

多个Iterable

之前说过,参数*iterable可以是多个可迭代对象的,我们来一探究竟:

def func(x,y,z):return x**2, y**2, z**2List1 = [1, 2]List2 = [1, 2, 3, 4]List3 = [1, 2, 3, 4, 5]res = map(func, List1, List2, List3)print(list(res))#输出 [(1, 1, 1), (4, 4, 4)]

可以看出,map()函数中传入了多个iterable。输出的结果中列表的长度为2。这是为什么?很简单,这里有一个知识点:输出的list的长度取决于*iterable中传入的litrable的最小长度,比如在上述中List1、List2和List3中最短的为List1,长度为2。

For循环取内容

我们知道,map()函数的返回为一个map对象,如:

我们之前的操作是使用list输出里面的内容的,实际上我们也可以使用for循环遍历的方式取值:

#for循环来取出内容def add_test(x):return x + 2string = [1,2,3,4,5,6]res = map(add_test, string)res_ls=[]for i in res:   res_ls.append(i)print(res_ls)

输出的结果跟上述一样,就不多分析了,有的小伙伴学习到这,就在想我们自己该怎么实现?

map()函数的功能呢?其实也不太难,我们接着看。

自实现Map()功能

def add_test(x):return x + 2# 实现map()函数功能def self_map(function,iterable):str_1=[]for each in iterable:each_num = function(each)str_1.append(each_num)return str_1.__iter__()string = [1,2,3,4,5,6]result = self_map(add_test,string)print(list(result))

上述代码的输出为:[3, 4, 5, 6, 7, 8],且完成了map函数的功能了。小伙伴们可能对代码代码str_1.__iter__()比较好奇,这个代码的功能就是将str_1转换为迭代器对象。

map()函数我们就介绍到这,接下来来看另一个高阶函数filter()。

Filter

看到这个函数的名字大家就知道其功能大概就是来过滤一些什么的,那具体是怎样的呢?

filter()是python内置函数,它会根据所传递的函数对指定的对象(可迭代)做过滤,原型如下:

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

可以看出该函数接收两个参数,第一个为函数,第二个为可迭代对象,序列的每个元素作为参数传递给函数进行判断,然后返回 True 或 False,最后将返回 True 的元素放到新列表(或迭代器)中。

Filter()实例

我们来看实例,注意filter()函数的返回时filter可迭代的对象,如:

,所以在输出的时候需要使用list()函数转换一下,当然了也可以使用for循环来取值。

def select_element(string):if 'p' in string:return True       # return 1else:return False       # return 0res_1 = filter(select_element,  ['1','2','3','python'])res_2 = filter(select_element, {'python':1,'知识':2,'学堂':3})print(list(res_1))print(list(res_2))# 输出均为# ['python']# ['python']

自实现Filter()功能

跟map()一样,我们自己来实现filter()的功能:

# 自实现filte()函数功能def select_element(string):if 'p' in string:return True       # return 1else:return False       # return 0def filter_test(function,iterable):str_1=[]for each in iterable:if function(each):str_1.append(each)return str_1string = ['1','2','3','python']res1 = filter_test(select_element,string)res2 = filter_test(lambda x:x=='python',string)print(res1)print(res2)

输出结果跟之前的一样,其中

res2 = filter_test(lambda x:x=='python',string)中使用了lambda函数,我们以后再具体介绍这类函数的使用。filter()函数我们就介绍到这,接下来来看另一个高阶函数reduce ()。

Reduce

跟map()、filter()类似,reduce()是一个以函数以及sequence为参数的高阶函数,其返回值为一个value值而不是迭代器对象。其原型如下:

reduce(function, sequence[, initial]) -> value

但reduce()传入的函数必须接收两个参数,比如func (x,y)满足条件,但是func(x,y,z)并不满足条件。

Initial为初始化的一个参数,可不填。(如果没有指定Initial的值那么其为sequence的第一个元素的值)。

Reduce()实例

在看reduce()函数的实例之前,我们来看一个图解释一下reduce的执行过程:

看图很简单:reduce每一次迭代,都将上一次的迭代结果与下一个元素一起传入function函数中,取得值以后将其与下一个元素一起继续下传…找到使用到sequence中的最后一个元素。

我们来看一个使用reduce()函数的实例:

# 需要functools从导入from functools import reducedef func(x, y):return x + ystring =  [1, 3, 5, 7, 9]result_1 = reduce(func,string)result_2 = reduce(func,string,100)print(result_1)print(result_2)

上述代码输出为:25和125,result_2使用initial = 100。

其中25的值可以这样理解:25 = ((((1+3)+5)+7)+9)

其中125的值可以这样理解:125 = (((((100+1)+3)+5)+57)+9)

其实上述reduce的计算过程还是比较好理解的,其实在Python中还有一个函数sum(),可以直接求职的,具体的求值语句:res = sum(string)。

自实现Reduce()功能

Reduce函数自定义实现也比较简单,我们来看看这个实现怎么写:

def func(x, y):return x + ydef self_reduce(function, string, initializer=None):it = iter(string)if initializer is None:value = next(it)else:value = initializerfor each_ele in it:value = function(value, each_ele)return valuestring = {1, 3, 5, 7, 9}# string = [1, 3, 5, 7, 9]result_1 = self_reduce(func,string)result_2 = self_reduce(func,string,100)print(result_1)print(result_2)

输出结果跟上述一样,这里的string = {1, 3, 5, 7, 9}是一个集合,即传入的是一个集合,当然了string = [1, 3, 5, 7, 9]也是可以的。

或者使用以下的方法实现Reduce()方法的功能也是可以的:

def func(x, y):return x + ydef self_reduce(function, iterable, initializer=None):if initializer is None:value =iterable.pop(0)else:value=initializerfor each_ele in iterable:value=function(value,each_ele)return valuestring = {1, 3, 5, 7, 9}result_1 = self_reduce(func,string,100)print(result_1)

输出结果为:125

总结

以上就是本次推文的所有内容啦!主要讲的是Python中的高阶函数,具体的内容涉及到高阶函数的定义和概念,具体的讲解了三个常用的高阶函数:map,filter,reduce的使用方法,同时也讲解了如何自己实现这三者的功能,这个自己实现三者功能的方法大家可以好好研究下。

在实际的工程项目中,运用好这些方法,不仅会减少代码量,而且在很大的程度上还能加速代码的运行速度。

最后,感谢大家的关注,如果觉得作者写得还不错的话,欢迎三连点赞分享再看支持,您的支持是我写作的最大动力,谢谢!

往期精选(?猛戳可查看)

Python实用教程系列——Logging日志模块

点赞和在看一下吧

map 长度_Python实用教程系列——高阶函数Map、Filter、Reduce相关推荐

  1. python中高阶函数map怎么用_python六十课——高阶函数之map

    1.高阶函数: 特点:函数的形参位置必须接受一个函数对象 分类学习: 1).map(fn,lsd1,[lsd2...]): 参数一:fn --> 函数对象 参数二:lsd1 --> 序列对 ...

  2. Python高阶函数--map、lambda、reduce、filter、zip

    一.map()函数 map()是 Python 内置的高阶函数,它接收一个函数 f 和一个 list,并通过把list 的每个元素依次作用在函数 f 上,得到一个新的 list 并返回. 例如,对于l ...

  3. Python函数详解:函数定义、调用,lambda函数,高阶函数map,filter,reduce,函数式编程,模块化设计、代码复用、函数递归、enumerate()

    一.函数 函数是一段具有特定功能的.可重用的语句组,通过函数名来表示和调用. 函数是一段代码的抽象和封装 函数是一段具有特定功能的.可重用的语句组 函数是一种功能的抽象,表达特定功能 两个作用:降低编 ...

  4. c++绝对值函数_Python自带自定义高阶函数实战

    一.概述 高阶函数,就是一个函数可以接收另一个函数作为参数的函数,或者接受一个或多个函数作为输入并输出一个函数的函数.scala与之类似. 二.自带常用高阶函数 1.map #map(f, Itera ...

  5. python高阶函数map_简单了解python高阶函数map/reduce

    高阶函数map/reduce Python内建了map()和reduce()函数. 我们先看map.map()函数接收两个参数,一个是函数,一个是Iterable,map将传入的函数依次作用到序列的每 ...

  6. py函数式编程(高阶函数map/reduce/filter/sorted、闭包函数/返回函数、匿名函数lamber、@装饰器decorator、偏函数functool.partial())

    #py函数式编程.py #高阶函数map/reduce/filter/sorted.闭包函数/返回函数.匿名函数lamber.@装饰器decorator.偏函数functool.partial()# ...

  7. python内置高阶函数求导_Python——函数式编程、高阶函数和内置函数,及

    Python--函数式编程.高阶函数及内置函数 函数式编程 一.不可变数据:不用变量保存状态不修改变量 二.第一类对象:函数即"变量" 1.函数名可以当做参数传递 2.返回值可以是 ...

  8. Swift 基础 高阶函数 forEach filter map compactMap compactMapValues flatMap reduce sort sorted shuffled ...

    一直觉得自己写的不是技术,而是情怀,一个个的教程是自己这一路走来的痕迹.靠专业技能的成功是最具可复制性的,希望我的这条路能让你们少走弯路,希望我能帮你们抹去知识的蒙尘,希望我能帮你们理清知识的脉络,希 ...

  9. Python高阶函数(map,reduce,filter)

    python内置常用高阶函数:. 称为 函数式编程,常常有一下特点 函数本身可以赋值给变量,赋值后变量为函数: 允许将函数本身作为参数传入另一个函数: 允许返回一个函数. 按常用排序 map() 函数 ...

最新文章

  1. 什么是REST?以及RESTful
  2. 查看SQL SERVER数据库的连接数
  3. 通过自定义注解与aop统一存储操作记录
  4. IOS开发UI篇之──自定义加载等待框(MBProgressHUD)
  5. JDK+SDK 环境变量记录
  6. 5G(6 )---5G NR 物理层 索引
  7. 奇怪的比赛--蓝桥杯
  8. Maven安装与配置(详细步骤)
  9. SSD原理解读-从入门到精通
  10. 微信小游戏代码包侵权的一种解决方案
  11. git clone下来的文件中.git文件被隐藏了
  12. 片上总线Wishbone 学习(二)Wishbone总线标准介绍
  13. 欲望无限--《贝奥武夫》给我们的启示
  14. Scrapy爬虫框架(实战篇)【Scrapy框架对接Splash抓取javaScript动态渲染页面】
  15. Navicat for Oracle配置
  16. matlab下载保姆级安装教程,哪个版本比较好些?
  17. 云仓一件代发是什么?对电商商家有什么好处?
  18. 如何按要求比较两个数的大小(不使用大于、小于以及if语句)
  19. SSL_2325【最小转弯问题】
  20. CentOS 7 分区方案

热门文章

  1. php获取表单信息的代码_php 表单数据的获取代码
  2. [javaweb] servlet 服务器端转发和客户端重定向 (四)
  3. 开辟与退出一个新的栈帧常用的汇编语言指令
  4. 【Python教程】常见字符串去除空格的教程
  5. Python字符串常用函数详解
  6. Python3 操作符重载方法
  7. python 引用和对象理解
  8. Python操作Oracle数据库:cx_Oracle
  9. 不要再问我Python2和Python3的Unicode 问题啦!
  10. iis8 php mysql_windows2012下 iis8+php5.2+mysql5 配置