一、高阶函数的定义

  高阶函数:就是把函数当成参数传递的一种函数,例如:

def add(x,y,f):
return f(x)+f(y)
print(add(-8,11,abs)

  结果:19

  解释:

     1.调用add函数,分别执行abs(-8)和abs(11),分别计算出他们的值

     2.最后再做和运算

二、Python内置的几个高阶函数

  1.map()函数

  map()函数接收两个参数,一个是函数(function),一个是序列(sequence),map将传入的函数依次作用到序列的每个元素,并把结果作为新的list返回。程序代码如下:

lt = (1,2,3,4,5)
def f2(x):
return x*x
ml = map(f2,lt)
print (type(ml))
print (ml)

  结果:

  解释:定义的函数f2。写f2时,指的是函数对象本身,当我们写f2(1)时,指的是调用f函数,并传入参数1,期待返回结果1。因此,map()传入的第一个参数是f2,即函数对象本身。像map()函数这种能够接收函数作为参数的函数,称之为高阶函数(Higher-order function)。

  2.reduce()函数:reduce把一个函数作用在一个序列[x1, x2, x3...]上,这个函数必须接收两个参数,reduce把结果继续和序列的下一个元素做累积计算,其效果就是:

reduce(f, [x1, x2, x3, x4]) = f(f(f(x1, x2), x3), x4)

  程序例子如下:

print("#############reduce################")
def f(x,y):
return x + y
print (reduce(f,[1, 2, 3, 4, 5],10))

  结果:

  3.filter()函数

  Python内建的filter()函数用于过滤序列。和map类似,filter()也接收一个函数和一个序列。和map不同的是,filter()把传入的函数依次作用于每个元素,然后根据返回值是true还是false决定保留还是丢弃。true保留,false丢弃

  例子:在一个list中,删掉偶数,只保留奇数,程序代码如下:

print ("###############filter##################")
a = [1, 2, 3, 4, 5]
def is_odd(x):
return x%2 == 1
print (filter(is_odd,a))

  结果:

  4.匿名函数

  • 没有函数名
  • 单条语句组成
  • 语句执行的结果就是返回值
  • 可用作sort的key函数

  例子如下:

def sum(x,y):
return x+y m = lambda x,y:x+y
print (m(4,5))

  结果:9

  

  5.sorted函数

  对List、Dict进行排序,Python提供了两个方法。对给定的List L进行排序:
  方法1.用List的成员函数sort进行排序,在本地进行排序,不返回副本
  方法2.用built-in函数sorted进行排序(从2.4开始),返回副本,原始输入不变

  sorted函数的语法:

def sorted(iterable, cmp=None, key=None, reverse=False):

可以看到其中第一个参数是可迭代对象,后面的参数都是具有默认值的,重点阐述如下:

  • iterable:是可迭代类型;
  • cmp:用于比较的函数,比较什么由key决定;
  • key:用列表元素的某个属性或函数进行作为关键字,有默认值,迭代集合中的一项;
  • reverse:排序规则. reverse = True  降序 或者 reverse = False 升序,有默认值。
  • 返回值:是一个经过排序的可迭代类型,与iterable一样。

 参数说明:

  (1)  cmp参数
  cmp接受一个函数,拿整形举例,形式为:

def f(a,b):
return a-b

  如果排序的元素是其他类型的,如果a逻辑小于b,函数返回负数;a逻辑等于b,函数返回0;a逻辑大于b,函数返回正数就行了
 
(2)  key参数
   key也是接受一个函数,不同的是,这个函数只接受一个元素,形式如下

def f(a):
return len(a)

  key接受的函数返回值,表示此元素的权值,sort将按照权值大小进行排序
 
(3) reverse参数
  接受False 或者True 表示是否逆序

例子:对字典进行排序,程序代码如下:

print ("############对字典进行排序####################")
mm = dict(a=1,c=3,d=9,b=10,f=4)
print (mm)
for i in mm:
print i
print ('#####################################')
for j in mm.iteritems():
print j
test = sorted(mm)
test =sorted(mm.iteritems(),key=lambda d:d[1])
print (test)

结果:

  

python的高阶函数与匿名函数的更多相关文章

  1. Python中的高阶函数与匿名函数

    Python中的高阶函数与匿名函数 高阶函数 高阶函数就是把函数当做参数传递的一种函数.其与C#中的委托有点相似,个人认为. def add(x,y,f): return f( x)+ f( y) p ...

  2. python 基础 4.3 高阶函数下和匿名函数

    一 .匿名函数 顾名思议就是没有名字的函数,那为什么要设立匿名函数,他有什么作用呢?lambda 函数就是一种快速定义单行的最小函数,可以用在任何需要函数的地方.   常规版: def fun(x,y ...

  3. python基础——高阶函数

    python基础——高阶函数 高阶函数英文叫Higher-order function.什么是高阶函数?我们以实际代码为例子,一步一步深入概念. 变量可以指向函数 以Python内置的求绝对值的函数a ...

  4. Python的高阶函数小结

    一. 高阶函数定义 简而言之,Python的高阶函数就是指一个函数作为参数传递给另外一个函数的用法. 举一个最简单的高阶函数来说明: >>> def add(x,y,f): retu ...

  5. Scala 基础(十一):Scala 函数式编程(三)高级(一)偏函数、作为参数的函数、匿名函数、高阶函数

    1 偏函数 1)在对符合某个条件,而不是所有情况进行逻辑操作时,使用偏函数是一个不错的选择 2)将包在大括号内的一组case语句封装为函数,我们称之为偏函数,它只对会作用于指定类型的参数或指定范围值的 ...

  6. python函数式编程之返回函数、匿名函数、装饰器、偏函数学习

    python函数式编程之返回函数 高阶函数处理可以接受函数作为参数外,还可以把函数作为结果值返回. 函数作为返回值 def laxy_sum(*args): def sum(): ax = 0; fo ...

  7. python——内置函数和匿名函数

    内置函数 接下来,我们就一起来看看python里的内置函数.截止到python版本3.6.2,现在python一共为我们提供了68个内置函数.它们就是python提供给你直接可以拿来使用的所有函数.这 ...

  8. python(day16)内置函数,匿名函数

    # add = lambda x,y:x+y # print(add(1,2)) # dic={'k1':10,'k2':100,'k3':30} # def func(key): # return ...

  9. python之内置函数,匿名函数

    什么是内置函数? 就是Python给你提供的,拿来直接用的函数,比如print,input等等.其实就是我们在创建.py的时候python解释器所自动生成的内置的函数,就好比我们之前所学的作用空间 内 ...

  10. Python函数(七)-匿名函数

    函数就是变量,定义一个函数就是把一个函数体赋值给一个函数名,函数和变量的回收机制也是一样的 匿名函数不需要指定函数名,只需要有函数体,然后把这个函数体赋给一个变量 Python中使用lambda来创建 ...

随机推荐

  1. Azure 本月最新活动,速度Mark!

    很多时候,为了知晓 Azure 相关活动的信息,需要到处查阅.问朋友同事,这样既麻烦又易造成延误.为方便广大粉丝,我们推出每月活动合集,帮您第一时间了解 Azure 最新活动,还等什么,一起来看吧! ...

  2. Eclipse Push出现rejected - non-fast-forward错误

    在 Push到服务器时有时会出现 rejected - non-fast-forward 错误,这是由于pull的代码而远端发生改变,此时再提交之前你需要将远端的改变合并到本地上 参考:https:/ ...

  3. less通用pc移动库

    // less 文件 (移动端通用less文件) // 作者 marchen // 时间 2014/9/1 // 协议 MIT // 只考虑webkit内核手机浏览器和火狐内核浏览器 // 自定义le ...

  4. 【JavaScript 封装库】BETA 1.0 测试版发布!

    /* 源码作者: 石不易(Louis Shi) 联系方式: http://www.shibuyi.net =============================================== ...

  5. mysql索引和正确使用方式

    一.索引类型 B树索引:大部分都是,因此B树的特性限制了索引如何使用:必须看看索引的正确使用限制(含组合索引的限制)http://blog.csdn.net/lovemdx/article/detai ...

  6. EF写INNER JOIN 链接

    面对多表的查询,一般都是多表连接后下面再写条件,但是有一种写法可以提升一下EF生成的语句的效率 首先先去查询每一个表,把每一个表对应的条件附加上去,注意:过滤数据最多的条件放在首先位置 var lt ...

  7. hdu-3015 Disharmony Trees---离散化+两个树状数组

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=3015 题目大意: 有一些树,这些树的高度和位置给出.现在高度和位置都按从小到大排序,对应一个新的ra ...

  8. 数长方形有多少个?POJ(1693)

    题目链接:http://poj.org/problem?id=1693 解题报告: 随机选两根横的,再找一下与这两根横线相交的竖线有多少根,m,那么就有(m-1)*m/2个长方形. #include ...

  9. Annual Congress of MUD(最大流)

    Annual Congress of MUD 时间限制: 1 Sec  内存限制: 128 MB提交: 80  解决: 10[提交] [状态] [讨论版] [命题人:admin] 题目描述 Multi ...

  10. ThinkPHP 更新数据 save方法

    ThinkPHP save() 方法 ThinkPHP 中使用 save() 方法来更新数据库,并且也支持连贯操作的使用. 例子: public function update(){ header(& ...