匿名函数

 lambda x: x + 1
# lambda:定义匿名函数的关键字
# x:形参
# x+1:程序处理逻辑
fun = lambda x: x + 1
print(fun(5))
#6
 fun = lambda name: name + "_new"
print(fun("Cindy"))
#Cindy_new

注意:

1、匿名函数一般不会单独使用,而是与其他函数配合使用

2、匿名函数的程序处理逻辑简单,不可以使用多行

 fun = lambda x, y, z: (x + 1, y + 1, z + 1)
print(fun(1, 3, 5))
# (2, 4, 6)

函数式编程

编程的方法论:

1、面向过程:找到解决问题的入口,按照一个固定的流程去模拟解决问题的流程

2、函数式编程:编程语言定义的函数+数学意义的函数,即用编程语言去实现数学函数,返回值是函数,没有for和while循环,所有循环使用递归实现。

  特点:a.不可变数据:不用变量保存状态,不修改变量 b.第一类对象:函数即“变量” c.尾调用优化(尾递归):在函数的最后一步(不一定是最后一行)进行递归

 def test1(x):
return x
def test2(y):
return test1(y) + 1 #不是尾递归
# 拆解:res = test1(y)
# return res + 1

3、面向对象

高阶函数

满足下列任一要求即为高阶函数:

1、函数的传入参数是一个函数名

2、函数的返回值是一个函数名

map函数

 def plus_one(x):
return x + 1
def minis_one(x):
return x - 1
def square(x):
return x**2
def map_test(func,num) :
nl = []
for i in num:
nl.append(func(i))
return nl num = [1,2,3,4,5]
nl = map_test(square,num)
print(nl)
# [1, 4, 9, 16, 25]
nl1 = map_test(plus_one,num)
print(nl1)
# [2, 3, 4, 5, 6]

也可以写成

 plus_one = lambda x: x + 1
minis_one = lambda x: x - 1
square = lambda x: x**2
def map_test(func,num) :
nl = []
for i in num:
nl.append(func(i))
return nl num = [1,2,3,4,5]
nl = map_test(square,num)
print(nl)
# [1, 4, 9, 16, 25]
nl1 = map_test(plus_one,num
print(nl1)
# [2, 3, 4, 5, 6]

最好的写法:

 def map_test(func,num) :
nl = []
for i in num:
nl.append(func(i))
return nl num = [1,2,3,4,5]
nl = map_test(lambda x: x + 1,num)
print(nl)
# [2, 3, 4, 5, 6]

map函数

功能:依次处理序列中的每个元素,得到的结果是一个“列表”,该“列表”元素个数及位置与原来一样

注意:得到的结果并不是真正的列表

 num = [1, 2, 3, 4, 5]
res = map(lambda x: x + 1, num)
print(res)
#<map object at 0x000002205AF765C0>
print(list(res))
# [2, 3, 4, 5, 6]

map的第一个参数是处理逻辑,第二个参数是可迭代对象,得到的结果是一个可迭代对象

 str = "hello"
res = map(lambda x: x.upper(), str)
print(list(res))
#['H', 'E', 'L', 'L', 'O']
print(res)
# <map object at 0x000002672E8282E8>

filter函数

功能:遍历序列中的每个元素,判断每个元素得到布尔值,True的元素保留下来,否则过滤掉

filter的第一个参数是处理逻辑,第二个参数是可迭代对象,得到的结果是一个可迭代对象

前一个参数得到的结果是布尔值,是True则保留,是False则过滤掉,可以在处理逻辑处+not来反过滤

 array = ["Allen", "Leo", "jennifer"]
res = filter(lambda x: x.istitle(), array)
print(res)
# <filter object at 0x00000291B3981470>
print("英文人名有:",list(res))
# 英文人名有: ['Allen', 'Leo']

也可以处理其他的

 people = [
{"name":"A","age":9000},
{"name":"B","age":900},
{"name":"C","age":18},
{"name":"D","age":50}
]
res = filter(lambda x: x["age"] < 100, people)
print(list(res))
# [{'name': 'C', 'age': 18}, {'name': 'D', 'age': 50}]

reduce函数

功能:把所有数据合并

 num = [1,2,3,100]
def reduce_test(func,num):
res = 1
for i in num:
res = func(i,res)
return res
res = reduce_test(lambda x,y: x * y, num)
print(res)
#

指定一个倍数

 num = [1,2,3,100]
def reduce_test(func,num,initial = None):
if initial == None:
res = 1
else:
res = initial for i in num:
res = func(i,res)
return res
res = reduce_test(lambda x,y: x * y, num, 10)
print(res)
#

reduce函数

 from functools import reduce

 num = [1, 2, 3, 100]
res = reduce(lambda x, y: x * y, num, 10)
print(res)
#

注意:map和reduce适合共同在大数据中使用

内置函数

abs() 绝对值

all() 判断内部所有元素的布尔值为Ture则Ture,否则假

注意:如果可迭代对象是空的返回True

any() 判断内部元素的布尔值有一个为Ture则Ture,否则假

bin() 十进制转成二进制

hex() 十进制转十六进制

oct() 十进制转八进制

bool() 求布尔值

注意:None,空,0的布尔值为False

bytes()转换成字节,需要指定编码

 name = "你好"
print(bytes(name,encoding = "utf-8"))
# b'\xe4\xbd\xa0\xe5\xa5\xbd'

.decode() 按指定编码方式解码

 print(bytes(name,encoding = "utf-8").decode("utf-8"))
# 你好

dir() 打印某一对象的方法,但不解释

help() 打印方法且详细解释

divmod(a,b) a除b的商并取余

 a = divmod(10,3)
print(a)
#(3, 1)

eval() 把字符串中的数据结构提取出来、把字符串中的数学运算计算出来

hash() 得出固定值,不能根据得到结果反推原数据,只要数据不变则得到结果不变

hashable即不可变数据类型,unhashable即可变数据类型

 name = "aff"
print("old_value:",hash(name))
print(hash(name))
print(hash(name))
name = "s"
print("new_value:",hash(name))
# old_value: 9152753171858710842
# 9152753171858710842
# 9152753171858710842
# new_value: -4828918846689666711

isinstance() 判断是否是类型

 print(isinstance(1,int))
print(isinstance(1.11,float))
print(isinstance("",int))
print(isinstance("",str))
print(isinstance([],list))
# True
# True
# False
# True
# True

globals() 打印全局变量(包括系统提供的)

locals() 打印局部变量

zip() 按照一一对应的关系生成一个个元组,两边长度不一致时从左到右取较短相同长度的元素

 print(zip(("a","b","c"),(1,2,3)))
#<zip object at 0x00000289A9C7E148>
print(list(zip(("a","b","c"),(1,2,3))))
#[('a', 1), ('b', 2), ('c', 3)]
print(list(zip(("a","b","c","d"),(1,2,3))))
#[('a', 1), ('b', 2), ('c', 3)]
print(list(zip(("a","b","c"),(1,2,3,4))))
#[('a', 1), ('b', 2), ('c', 3)]

只要传入的两个值都是有序列的即可

 p = {"name":"Jenny","age":18,"gender":"female"}
print(list(zip(p.keys(),p.values())))
#[('name', 'Jenny'), ('age', 18), ('gender', 'female')]
print(list(zip("hello","")))
# [('h', '1'), ('e', '2'), ('l', '4'), ('l', '5'), ('o', '4')]

max()取最大值      min()取最小值

对字典比较默认比key,从左到右一一比较

 l = {"A_age":18,'B_age':89,"C_age":50,"D_age":30}
m_list = list(zip(l.values(),l.keys()))
print(m_list)
print(max(m_list))
# [(18, 'A_age'), (89, 'B_age'), (50, 'C_age'), (30, 'D_age')]
# (89, 'B_age')

从元素的第一位往后比值,一旦有一位是最大的,后面不再比较

 d = {"a10","a8","a03"}
print(max(d))
#a8 第一位一样,比第二位,8>1>0,直接得出最大值,后面不比了

可以指定比较逻辑

 ages = [
{"name": "a", "age": 18},
{"name": "b", "age": 50},
{"name": "c", "age": 99}]
print(max(ages, key=lambda dic: dic["age"]))
# {'name': 'c', 'age': 99}

sorted() 升序排序,用法与max()类似

注意:排序本质就是比较大小,同类型之间才可以比较

 prices = {
"a": 900,
"b": 800,
"c": 1000
}
print(sorted(prices, key=lambda key: prices[key]))
# ['b', 'a', 'c']
print(sorted(zip(prices.values(), prices.keys())))
# [(800, 'b'), (900, 'a'), (1000, 'c')]

ord() 打印出ASCII码字母代表的数字

chr() 打印出ASCII码数字代表的字母 pow()

 print(chr(97))
print(ord("a"))
# a
#

pow()

pow(a,b) 求a^b

pow(a,b,c) 求a^b%c

reversed() 反转

反转后没有保存

round() 四舍五入

set() 变成集合

slice()切片

主要为了提高程序的可读性,可以指定步长

 m = "hello"
s = slice(3,5)
print(m[s])
#lo

sum() 求和

type() 查看数据类型

vars() 如果没有参数,等于locals(),有参数则显示帮助

import 导入模块

 import test #调用.py文件名
test.hi()
#HELLO
z = __import__("test") #调用字符串名
z.hi()
#HELLO

Python学习(七)——匿名函数、map函数、filter函数、reduce函数与其他内置函数的更多相关文章

  1. 辅助函数和高阶函数 map、filter、reduce

    辅助函数和高阶函数 map.filter.reduce: 一.辅助函数:(1-1)响应式函数 (数组更新检测):    push()    pop()    shift()    unshift()  ...

  2. Python3基础(4)匿名函数、装饰器、生成器、迭代器、内置函数、json&pickle序列化、软件目录开发规范、不同目录间模块调用

    ---------------个人学习笔记--------------- ----------------本文作者吴疆-------------- ------点击此处链接至博客园原文------ 1 ...

  3. 【Python全栈笔记】04 [模块二] 18 Oct lambda表达式, 内置函数

    lambda表达式 lambda表达式是函数的一种简化,如下面两种函数定义方法,实际上效果是一样的. 使用lambda表达式的函数,func2是函数名,lambda: 后面的123 即为返回值. de ...

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

    map()函数,接收两个参数,一个是函数,一个是序列,map()把传入的函数依次作用于序列的每个元素,并把结果作为新的序列返回: aa = [1, 2, 3, 4, 5] print("ma ...

  5. python 函数map()、filter()、reduce()

    map()函数    将一个列表进行遍历,对每一个字符串进行处理: 例如: num_list = ["我","是","哈哈","太 ...

  6. 内置函数--map,filter,reduce

    一.map class map(object): """ map(func, *iterables) --> map object Make an iterator ...

  7. python学习笔记:(三)list(列表)常用的内置方法

    list(列表)包含一些内置的方法,以下为详细介绍: (方法调用:对象.方法(参数)) 1.append() 在列表的末尾添加新的对象 如: lst=[1,2,3] lst.append(4) --- ...

  8. Python经常使用内置函数介绍【filter,map,reduce,apply,zip】

    Python是一门非常简洁,非常优雅的语言,其非常多内置函数结合起来使用,能够使用非常少的代码来实现非常多复杂的功能,假设相同的功能要让C/C++/Java来实现的话,可能会头大,事实上Python是 ...

  9. Python基础(七)内置函数

    今天来介绍一下Python解释器包含的一系列的内置函数,下面表格按字母顺序列出了内置函数: 下面就一一介绍一下内置函数的用法: 1.abs() 返回一个数值的绝对值,可以是整数或浮点数等. 1 2 3 ...

  10. Python基础学习参考(三):内置函数

    一:内置函数 在第一篇文章中,我们简单的认识了一下print()函数和input()函数,也就是输入和输出,这些函数我们可以直接的调用,不要自己定义或者引入什么,对吧?想这样的函数就叫做内置函数.这里 ...

随机推荐

  1. LaTeX技巧002:\section{}章节命令添加中文编译不了问题

    在宏包hyperref前面添加选项CJKbookmarks \usepackage[CJKbookmarks]{hyperref} 并且把这句话尽可能地加在导言区的最底部,即尽可能靠近 \begin{ ...

  2. TODO:rest和restful接口是什么?

    todo: 参考: http://www.ruanyifeng.com/blog/2018/10/restful-api-best-practices.html https://www.jianshu ...

  3. FJUTOJ-3682 LRU算法的实现2 (链表+哈希)

    传送门 此题让我们实现一个LRU的模板类.本题较简便且高效的写法是维护一个std::list和一个std::unordered_map. std::list 与 std::unordered_map ...

  4. 表结构修改以及sql增删改查

    修改表结构 修改表名 alter table 表名 rename 新名 增加字段 alter table 表名 add 字段名 数据类型 约束 删除字段 alter table 表名 drop 字段名 ...

  5. JS高级---复习和课程介绍

    课程介绍 浅拷贝 深拷贝----------|======>递归 遍历DOM树-------|======>递归------晚上能够把代码写出来是最好的   正则表达式-------很重要 ...

  6. selenium 模拟滑动解锁

    来源:Selenium模拟JQuery滑动解锁   (selenium +Python ) 本文:selenium+Java package cn.gloryroad; import org.open ...

  7. c#中的yield词法

    yield关键字的作用是将当前集合中的元素立即返回,实例: 通过断点可以看到,控制台每显示一个集合中的元素,都会到query方法中去取集合元素. 其实yield return是“语法糖”,其本质是生成 ...

  8. Oracle VM VirtualBox - 启用 VT-x/AMD-V 支持

    问题描述Oracle VM VirtualBox引入OVF模板时,报错:VT-x/AMD-V 硬件加速已被启用, 但当前处于无效状态. 您虚拟电脑内的操作系统将无法检测到64位的处理器,因此也将无法启 ...

  9. 【Redis运行状态下切换RDB备份至AOF备份】

    "redis持久化方式有哪些?又有何区别? rdb:基于快照的持久化,速度更快,一般用作备份,主从复制也是依赖于rdb持久化功能. aof:以追加的方式记录redis操作日志的文件,可最大程 ...

  10. mediasoup-demo解析-客户端

    1.gulp任务管理 app官方文档 npm start启动app,执行脚本: "start": "gulp live" 该命令用启动gulp顺序任务组合liv ...