Python map/reduce/filter/sorted函数以及匿名函数
1. map() 函数的功能:
map(f, [x1,x2,x3]) = [f(x1), f(x2), f(x3)]
def f(x):
return x*x
a = map(f, [1, 2, 3, 4, 5])
b = map(f, (6, 7, 8, 9))
print a
print b
# [1, 4, 9, 16, 25]
# [36, 49, 64, 81] # a = map(f, 1,2,3,4,5,6,7)
# print a
# Traceback (most recent call last):
# File "C:/workplace/SVC/DiskVideoTask/modules/test_mapReduce.py", line 8, in <module>
# a = map(f, 1,2,3,4,5,6,7)
# TypeError: argument 2 to map() must support iteration
2. reduce()的用法:
reduce(f, [x1, x2, x3]) = f(f(f(x1,x2),x3),x4).
def add(x,y):
return x+y print reduce(add,[1,2,3,4,5])
# def str2int(s):
def fn(x,y):
return x * 10 + y def char2num(s):
return {'':0, '':1, '':2, '':3,
'':4, '':5, '':6, '':7, '':8,'':9
}[s]
return reduce(fn,map(char2num,s)) print str2int('') #
3. filter()的用法
filter(f, [x1,x2,x3]) = [x1], f(x1)=True, f(x2)=False, f(x3)=False
注意: filter参数中f函数返回的是布尔类型的值, filter根据f(x1)返回的值是否是True而决定是否返回x1.
def is_odd(n):
return n % 2 == 1 print filter(is_odd, [1,2,3,4,5,6,7]) def not_empty(s):
return s and s.strip()
# 若 s and s.strip() 这个与命题结果为空字符,那么结果为False.
# 若 s and s.strip() 这个与命题结果为非空字符串,那么结果为True. print filter(not_empty, ['A', 'B ', '', None, ' '])
# ['A', 'B ']
4. sorted()的用法
内建函数sorted()默认排序顺序为:
对于两个元素x和y,如果x<y,则返回-1;
如果x==y,则返回0;
如果x>y, 则返回1.
print sorted([36,5,11,9,22])
# [5, 9, 11, 22, 36]
# 如果是数字,默认按从小到到的顺序排列.
print sorted(['I','Hello','Gim', 'you', 'him', 'apple', 'banana'])
# ['Gim', 'Hello', 'I', 'apple', 'banana', 'him', 'you']
# 如果是字符串,默认先比较大写字符串的大小,然后再比较小写字符创的大小。都是从小到大顺序排列。
sorted()函数也是一个高阶函数。可以接收一个自定义的排序函数,从而来为给出的序列排序。
若希望数字从大到小排列。那么自定义一个函数revered_cmp
def revered_cmp(x,y):
if x > y:
return -1
if x < y:
return 1
return 0 print sorted([36,5,11,9,22], revered_cmp)
# [36, 22, 11, 9, 5]
若希望字符串忽略大小写来排序。那么字定义一个函数cmp_ignore_case.
def cmp_ignore_case(s1,s2):
u1 = s1.upper()
u2 = s2.upper()
if u1 > u2:
return 1
if u1 < u2:
return -1
return 0
print sorted(['I','Hello','Gim', 'you', 'him', 'apple', 'banana'], cmp_ignore_case)
# ['apple', 'banana', 'Gim', 'Hello', 'him', 'I', 'you']
显然,map, reduce, filter, sorted都是高阶函数。分别实现了映射,连续计算,过滤,排序。
高阶函数的抽象能力是非常强大的,而且,核心代码可以保持得非常简洁。
匿名函数
Python有两种函数,一种是用def定义的,另一种则是接下来要谈的匿名函数,用lambda定义的。
为什么要用匿名函数?
1. 有些程序代码只出现一次,即一次性的,那么用匿名函数,不需要定义函数名,节省内存中的变量空间。
2. 使代码更加简洁。
result = filter(lambda x: x>3, [1,2,3,4,5])
print result
#[4, 5]
若filter函数中的匿名函数所起的作用是一次性的,我们就用匿名函数来实现这个函数功能。
匿名函数的几个规则:
1. 不用函数名
2. 可以没有参数,可以有多个参数,参数可以带默认值。
3. 函数中只能写一个表达式。
4. 不用写return, 返回值就是表达式的结果
应用:
匿名函数一般应用于函数式编程。常和map, reduce 和 filter函数结合使用。
Python map/reduce/filter/sorted函数以及匿名函数的更多相关文章
- python--函数式编程 (高阶函数(map , reduce ,filter,sorted),匿名函数(lambda))
1.1函数式编程 面向过程编程:我们通过把大段代码拆成函数,通过一层一层的函数,可以把复杂的任务分解成简单的任务,这种一步一步的分解可以称之为面向过程的程序设计.函数就是面向过程的程序设计的基本单元. ...
- Python进阶:函数式编程(高阶函数,map,reduce,filter,sorted,返回函数,匿名函数,偏函数)...啊啊啊
函数式编程 函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数调用,就可以把复杂任务分解成简单的任务,这种分解可以称之为面向过程的程序设计.函数就是面向过程的程序设计 ...
- (转)Python进阶:函数式编程(高阶函数,map,reduce,filter,sorted,返回函数,匿名函数,偏函数)
原文:https://www.cnblogs.com/chenwolong/p/reduce.html 函数式编程 函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数 ...
- python函数式编程学习之map,reduce,filter,sorted
map(f, list)函数用于将函数f运用到list里的每个元素中 写个例子 def pow(x): return x*x map(pow, [2,3,4]) reduce(f, list)函数用于 ...
- python基础之map/reduce/filter/sorted
---map(fun,iterable) 首先来看一看map()函数,map函数接受两个参数,第一个参数是函数的名称,第二个参数一个可迭代对象.即map(fun,iterable) map函数就是将具 ...
- 函数式编程 高阶函数 map&reduce filter sorted
函数式编程 纯函数:没有变量的函数 对于纯函数而言:只要输入确定,那么输出就是确定的.纯函数是没有副作用的. 函数式编程:允许把函数本身作为参数传入另一个函数,还允许返回一个函数 高阶函数:一个函数的 ...
- python map, reduce,filter 使用
参考python built-on function: http://docs.python.org/2.7/library/functions.html?highlight=map%20reduce ...
- Python map,reduce,filter,apply
map(function, iterable, ...) map()函数接收两个参数,一个是函数,一个是可迭代的对象,map将传入的函数依次作用到序列的每个元素,并把结果作为新的list返回. 基本等 ...
- [python基础知识]python内置函数map/reduce/filter
python内置函数map/reduce/filter 这三个函数用的顺手了,很cool. filter()函数:filter函数相当于过滤,调用一个bool_func(只返回bool类型数据的方法) ...
随机推荐
- PIE SDK栅格数据的创建
1. 功能简介 目前在地理信息领域中数据包括矢量和栅格两种数据组织形式.每一种数据有不同的数据格式,目前PIE SDK支持多种数据格式的数据创建,下面对栅格数据格式的数据创建功能进行介绍. 2. 功能 ...
- 2019.03.27 读书笔记 关于GC垃圾回收
在介绍GC前,有必要对.net中CLR管理内存区域做简要介绍: 1. 堆栈:用于分配值类型实例.堆栈主要操作系统管理,而不受垃圾收集器的控制,当值类型实例所在方法结束时,其存储单位自动释放.栈的执行效 ...
- ELK 插件(一) ---- head
一, 插件介绍 01, ElasticSearch Head是什么? ElasticSearch Head是集群管理.数据可视化.增删查改.查询语句可视化工具.可以对集群进行傻瓜式操作.你可以通过插件 ...
- URL篇之相对URL
URL有两种方式:绝对的和相对的. 绝对URL中包含有访问资源所需的全部信息,是访问网络资源必须的. 相对URL是不完整的,要从相对URL中获取访问资源所需的全部信息,就必须相对于另一个被称为其基础( ...
- JQuery实现表格的全选和反选,以及分页勾选保存(laypage插件分页的使用)
需求: 1.全选与取消全选 2.单个勾选,点击表格单元格中checkbox勾选,也可以在点击行勾选,便与用户操作 3.分页勾选保存 4.固定表头 功能一: 说明:操作全选按钮的同时,遍历每一个tr中的 ...
- 关于Json字符串"反序列化Error reading JObject from JsonReader. Current JsonReader item is not an object: StartArray. Path..."
描述的很清楚就是说给它的不是一个对象,而是一个数组,所以他在建议你用JArray去解析,但是你明明就是给它的一个对象,并不是一个数组 这是我下意识的去把我的json字符串中的"[ ]&quo ...
- 如何去除表单元素获得焦点时的外边框:outline (轮廓)
我们在做制作表单页面时,经常会需要消除表单元素带来的边框,这时候我们需要用到两个属性: 1.表单元素未激活状态下的边框,不实现边框: border:none; 2.表单元素获得焦点时的轮廓,隐藏轮廓: ...
- (四)selenium打开和关闭浏览器
一.Selenium简介 Selenium3.0主要变更特性: ①移除seleniumRC ②FireFox和Safari推出了自己的driver(geckodriver 和 Safaridriver ...
- 数据从mysql迁移到hbase的一些思考及设计
一.进行迁移的原因 由于业务的发展,使用mysql进行建立索引进行搜索已经造成数据流的瓶颈卡在了数据库io,例如每次dump全表的时候,会造成压力过大,造成耗时很长,并且当前的数据量基本上已经达到了亿 ...
- [转]EntityFramework中常用的数据修改方式
本文转自:http://blog.csdn.net/itmaxin/article/details/47662151 上一篇文章里提到了 EntityFramework中常用的数据删除方式,那么修改对 ...