匿名函数
语法:
函数名 = lambda 形参列表: 返回值
-
没有默认值的参数放在有默认值的前面
相当于
def 函数名(形参列表): return 返回值
注意:匿名函数除了定义以及参数类型说明和普通函数不一样,其他都是一样的
变量作用域 – 变量能使用的范围
根据变量作用域的不同将变量分为全局变量和局部变量两种
全局变量
没有定义在函数和类里面的变量都是全局变量,全局变量的作用域是从定义开始到程序结束
局部变量
定义在函数中的变量是局部变量(形参也是局部变量),局部变量的作用域是从定义开始到函数结束
全局变量和局部变量的底层逻辑
-
全局变量保存在全局的栈区间,全局栈区间是在程序结束的时候才会自动释放;
-
每次调用函数的时候系统会自动为这个函数创建一个临时的栈区间(从C开始就是这样),用来保存函数运行过程中产生的数据,所以局部变量也是保存在这个临时栈区间中的,当函数调用结束这个临时栈区间会自动释放
全局变量 global
作用:1.在函数内部去修改全局变量的值
2. 在函数内部定义全局变量
注意:global只能在函数内部使用,使用的时候必须在变量第一次使用之前
a = 10
name = 'kitty'
def func1():
# 在函数内部给全局变量赋值,不会修改全局变量的值而是创建一个新的局部变量
a = 20
# 函数内部使用变量前加global,操作的是全局变量,不会创建新的局部变量
global name
name = 'Jimmy'
print(f'函数里面的a:{
a},name:{
name}')
func1()
print(f'函数外面的a:{
a},name:{
name}')
函数就是变量
python中定义函数其实就是定义一个类型是function的变量,函数名就是名
变量能做的事,函数都可以做
返回值高阶函数
返回值是函数的函数
高阶函数
实参高阶函数
如果一个函数的参数是函数,这个就是实参高阶函数
常用的实参高阶函数:max、min、sorted、map、reduce
max(序列, key=函数)
根据函数指定的规则来获取序列中最大的元素
min(序列, key=函数)
根据函数指定的规则来获取序列中最小的元素
sorted(序列, key=函数)
根据函数指定的规则对序列排序
函数要求:1. 有且只有一个参数,这个参数代表序列中的每个元素
2. 有一个返回值,返回值就是比较对象
map(函数, 序列1)
函数要求:1.有且只有一个参数,参数指向后面序列中的每个元素
2.有一个返回值,返回值就是新序列中的元素
map(函数, 序列1, 序列2)
函数要求:1.有且只有2个参数,参数指向后面2个序列中的每个元素
2.有一个返回值,返回值就是新序列中的元素
map(函数, 序列1, 序列2,...)
注意:map函数的返回值是一个map对象(本质是一个序列)
reduce 将序列中的元素合并成一个数据
注意:reduce在使用前必须先导入
reduce(函数, 序列, 初始值)
函数要求:1.有且只有两个参数:第一个参数指向初始值,第二个参数指向序列中的每个元素
2.有一个返回值,返回值需要描述清楚合并的方式
-
已知列表points中保存的是每个点的坐标(坐标是用元组表示的,第一个值是x坐标,第二个值是y坐标)
points = [
(10, 20), (0, 100), (20, 30), (-10, 20), (30, -100)
]以下问题使用实参高阶函数来解决
- 获取列表中y坐标最大的点
- 获取列表中x坐标最小的点
- 获取列表中距离原点最远的点
- 将点按照点到x轴的距离大小从大到小排序
# 获取列表中y坐标最大的点 result = max(points, key=lambda y: y[-1]) print(re