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