总结
return的作用
1,将数据作为函数的返回值返回
2.结束函数(执行函数体的时候,如果遇到return,函数直接结束)
注意:return只能在函数体中使用
二,变量作用域
变量作用域指的是变量定义完成后可以使用的有效范围。
根据变量变量作用域的不同,可以将变量分为 全局变量 和 局部变量 两种。
全局变量
Python中没有定义在函数中或者类中的变量默认都是全局变量。
作用域:从定义函数到程序结束。
局部变量
定义在函数中的变量就是局部变量(形参也是局部变量)
作用域:从定义开始到函数结束。
全局变量和局部变量的存储原理
全局变量默认保存在全局栈区间,全局栈区间会在程序结束后自动释放。
调用函数的时候系统会自动为这个函数创建一个临时栈区间,用来保存在函数中产生的数据(局部变量就是保存在函数对应的临时栈区间中的),函数对应的临时栈区间会在函数调用结束的时候自动释放。
在函数中可以通过关键字global修改局部变量的保存方式
global 变量 —— 把局部变量改成全局变量
- 在函数内部定义全局变量用global
- 在函数内部修改全局变量的值用global
匿名函数 - 没有名字的函数
语法:
函数名 = lambda 形参列表:返回值
相当于:
def 函数名(形参列表):
return 返回值
案例:定义一个匿名函数,求任意两个数的和
sum_2 = lambda num1,num2:num1+num2
注意:
- 匿名函数的形参至少一个
- 匿名函数的调用和普通函数一样
- 无默认值的类型说明在匿名函数中不能用
实参高阶函数
函数的参数是函数的函数就是实参高阶函数
给参数是函数的参数传参:
1.使用普通函数函数名
2.使用匿名函数
重点:掌握系统或者第三方库提供的实参高阶函数的用法
常见的实参高阶:max,min,sorted,列表.sort,map,reduce
max(序列) - 直接比较序列中元素的大小,求最大值
max高级用法:
max(序列,key=函数) - 按照函数指定的规则比较序列中元素的大小获取最大值
函数的要求:
- 有且只有一个参数(这个参数代表序列中的每个元素)
- 有一个返回值(返回值就是比较对象)
map - 基于原序列中的元素创建一个新的序列
map(函数,序列) - 通过函数描述的规则基于序列中的元素创建一个新的序列
函数要求:
1.有且只有一个参数(代表后面的这个序列中每个元素)
2.有一个返回值(返回值就是新序列中元素)
如果有两个序列,那就有且只有两个参数(参数和序列一一对应),返回值不变
reduce - 将序列中元素合并成一个数据(基于原序列中所有的元素得到一个数据)
语法:
reduce(函数,序列,初始值) - 按照函数制定的规则将序列中的元素合并成一个数据
函数的要求:
1.有且只有两个参数(第一个参数指向初始值,第二个参数代表序列中的每个元素)
2.需要一个返回值(返回值就是合并规则)
初始值:累积求数值和,初始值是0
累积求数值乘积,初始值是1
字符串合并,初始值是空串
什么是迭代器(iter)
迭代器是容器型数据类型(可以遍历,也可以转换成列表)
无法按直接提供一个迭代器,只能将其他序列转换成迭代器。
特点1.打印迭代器的时候无法查看到元素有哪些
2.无法通过len获取迭代器中元素的个数
3.如果要使用迭代器中的元素必须将元素从迭代器中取出来(取走),取走的元素会从迭代器中永远消失(用一个少一个)
任何数据都可以作为迭代器的元素
1.创建迭代器
i1 = iter(‘abc’)
i2 = iter([10,20,30,40])
2.打印迭代器无法查看元素
print(i1)
print(i2)
3.迭代器无法统计个数
获取迭代器中的元素
无论以任何方式获取到了迭代器中的某个元素,那么这个元素一定会从迭代器中消失。
1.获取单个元素:
next(迭代器) - 获取迭代器最前面的元素
2.遍历迭代器
for 变量 in 迭代器:
循环体