Python 函数式编程 1 高阶函数

高阶函数

Q:什么是高阶函数
A:一个函数接收另一个函数作为参数这种函数就称之为高阶函数
简单举个例子:

def add(x, y, f):return f(x) + f(y)

使用这个函数:

>>> add(-5, 6, abs)
11

它是这样执行的:

x = -5
y = 6
f = abs
f(x) + f(y) ==> abs(-5) + abs(6) ==> 11
return 11

map/reduce

map

map()是一个高阶函数map()函数接收两个参数,一个是函数,一个是Iterablemap将传入的函数依次作用到序列的每个元素,并把结果作为新的Iterator返回。

def f(x):return x * x
r = map(f, [1, 2, 3, 4, 5, 6, 7, 8, 9])print(r)
print(list(r))

运行:

<map object at 0x000000821D2A11D0>
[1, 4, 9, 16, 25, 36, 49, 64, 81]

由于结果r是一个IteratorIterator惰性序列,因此通过list()函数让它把整个序列都计算出来并返回一个list

再比如,把这个list所有数字转为字符串

>>> list(map(str, [1, 2, 3, 4, 5, 6, 7, 8, 9]))
['1', '2', '3', '4', '5', '6', '7', '8', '9']

reduce

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

举个例子:一个序列求和

>>> from functools import reduce
>>> def add(x, y):
...     return x + y
...
>>> reduce(add, [1, 3, 5, 7, 9])
25

当然求和运算可以直接用Python内建函数sum(),没必要动用reduce

>>> sum([1, 3, 5, 7, 9])
25

再举个例子:把序列[1, 3, 5, 7, 9]变换成整数13579

>>> from functools import reduce
>>> def fn(x, y):
...     return x * 10 + y
...
>>> reduce(fn, [1, 3, 5, 7, 9])
13579

再举个例子:把str转换为int

>>> from functools import reduce
>>> def fn(x, y):
...     return x * 10 + y
...
>>> def char2num(s):
...     return {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}[s]
...
>>> reduce(fn, map(char2num, '13579'))
13579

整理代码:

from functools import reducedef str2int(s):def fn(x, y):return x * 10 + ydef char2num(s):return {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}[s]return reduce(fn, map(char2num, s))

总结:
假设Python没有提供int()函数,你完全可以自己写一个把字符串转化为整数的函数,而且只需要几行代码!

filter

filter()函数用于过滤序列。filter()也接收一个函数和一个序列filter()函数把传入的函数依次作用于每个元素,根据返回值是True还是False决定保留还是丢弃该元素。

举例:

一个list中,删掉偶数,只保留奇数:

def is_odd(n):return n % 2 == 1list(filter(is_odd, [1, 2, 4, 5, 6, 9, 10, 15]))
# 结果: [1, 5, 9, 15]

一个序列中的空字符串删掉:

def not_empty(s):return s and s.strip()list(filter(not_empty, ['A', '', 'B', None, 'C', '  ']))
# 结果: ['A', 'B', 'C']

strip()函数用法:
当没有形参传入strip()函数时,默认删除空白符(包括'\n', '\r', '\t‘, ' '
strip()函数的具体用法请到这里学习:http://www.cnblogs.com/kaituorensheng/archive/2013/05/23/3096028.html


filter()函数返回的是一个Iterator,所以 要强迫filter()完成所有计算,就使用list()函数获取所有结构,返回一个list.

sorted

sorted()函数是:排序算法。

>>> sorted([36, 5, -12, 9, -21])
[-21, -12, 5, 9, 36]

sorted()函数也是一个高阶函数。接收一个key函数来实现自定义的排序。比如:

>>> sorted([36, 5, -12, 9, -21], key=abs)
[5, 9, -12, -21, 36]

再看一个字符串排序的例子:

>>> sorted(['bob', 'about', 'Zoo', 'Credit'])
['Credit', 'Zoo', 'about', 'bob']

默认的排序规则是:按照ASCII的大小比较的,由于'Z' < 'a',所以,大写字母Z会排在小写字母a的前面。

sorted传入key函数,忽略大小写的排序:

>>> sorted(['bob', 'about', 'Zoo', 'Credit'], key=str.lower)
['about', 'bob', 'Credit', 'Zoo']

实现反向排序,传入第三个参数reverse=True

>>> sorted(['bob', 'about', 'Zoo', 'Credit'], key=str.lower, reverse=True)
['Zoo', 'Credit', 'bob', 'about']

参考网站:
http://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/0014318230588782cac105d0d8a40c6b450a232748dc854000

转载于:https://www.cnblogs.com/aobosir/p/5928634.html

Learning Python 012 函数式编程 1 高阶函数相关推荐

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

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

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

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

  3. python函数式编程、高阶函数

    1.map() python内置的高阶函数,接收一个函数f和一个list,并通过把函数f依次作用在list的每个元素上,得到一个新的list并返回. def f(x):return x * xprin ...

  4. Scala - 快速学习08 - 函数式编程:高阶函数

    函数式编程的崛起 函数式编程中的"值不可变性"避免了对公共的可变状态进行同步访问控制的复杂问题,能够较好满足分布式并行编程的需求,适应大数据时代的到来. 函数是第一等公民 可以作为 ...

  5. 函数式编程与高阶函数

    初步接触了以下几种高阶函数,还用的不是很熟练. 1.map(): 这个函数接受两个参数: 'map(function, sequence)' 第一个必需参数是一个编辑好的函数,第二个参数是一个序列,m ...

  6. Python 函数式编程,Python中内置的高阶函数:map()、reduce()、filter()与sorted(),Python中返回函数

    函数式编程 是一种编程范式,比函数更高层次的抽象. 函数式编程将计算视为函数而非指令. 纯函数式编程:不需要变量,没有副作用,测试简单. 支持高阶函数,代码简洁. Python 支持的函数式编程 不是 ...

  7. python绝对值编程_Python高阶函数

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

  8. python采用函数式编程模式吗_Python函数与函数式编程

    1 函数 函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数能提高应用的模块性,和代码的重复利用率.你已经知道Python提供了许多内建函数,比如print().但你也可以自己创 ...

  9. C#函数式编程之标准高阶函数

    何为高阶函数 大家可能对这个名词并不熟悉,但是这个名词所表达的事物却是我们经常使用到的.只要我们的函数的参数能够接收函数,或者函数能够返回函数,当然动态生成的也包括在内.那么我们就将这类函数叫做高阶函 ...

  10. 【吐血整理】Python 常用的几种高阶函数和简单的迭代函数

    目录 一.all() 函数--判断可迭代对象中的元素是否全为True 二.any() 函数--判断可迭代对象是否全为假值 三.filter() 函数--通过指定条件过滤序列 四.map() 函数--- ...

最新文章

  1. 在Windows C程序中使用Unicode编码
  2. Ubuntu系统---C++之Eclipse 开始工程项目
  3. Accoridion折叠面板
  4. Linux内核:容器底层cgroup如何使用
  5. P3172-[CQOI2015]选数【dp,容斥】
  6. Java学习之斐波那契数列实现
  7. 预训练模型对实体的表示能力差?一个简单有效的解法来了!(开源)
  8. istio多集群链路追踪,附实操视频
  9. 晚上睡觉的时候应该把wifi关掉吗?
  10. hdu I Hate It
  11. 2018-2019-20175203 实验二 《Java面向对象程序设计》
  12. java企业员工管理系统_java企业员工考勤管理系统
  13. php url伪静态,PHP url伪静态
  14. c语言cmp函数含义,【C艹】关于sort用法之重构cmp(comp)函数的笔记
  15. Remix OS——一个很有魅力的Android系统
  16. 双非本科,三年逆袭鹅厂,靠的不仅仅是努力
  17. 计算机的文档库在哪哪里,电脑的word文档在哪里
  18. aI_Challenger 机器翻译
  19. 什么是GPT,如何克隆GPT类型的磁盘?
  20. WebGoat 网安攻击模拟操训

热门文章

  1. C++ {}作用域 return
  2. 区块链 FISCO BCOS智能合约存储存放位置
  3. html语言的前景,HTML5语言的优势有哪些?2021年还有前景么?
  4. SpringMVC学习(四)结果跳转的方式:转发和重定向
  5. css 三种颜色表示,css颜色表示法
  6. java static 初始化顺序_java static 初始化顺序语法并不正确
  7. 文章中的代码添加语法高亮
  8. linux ubuntu/centos相关收藏
  9. Spring boot 2.x + Thymeleaf 公共部分抽取
  10. 小D课堂 - 新版本微服务springcloud+Docker教程_5-03 feign结合hystrix断路器开发实战上...