day10 - 函数2(总结)

1.recode

1.1.函数的调用
过程:
回到函数申明的位置
用实参给形参赋值
执行函数体
获取返回值
回到函数调用的位置
压栈:
当调用函数的时候,系统会自动在栈区间开辟空间保存函数调用过程产生的数据(形参,函数中申明的变量)
1.2.返回值
看有没有遇到return,遇到了函数的返回值就是return后面的值,没有遇到就是None
函数表达式的结果就是函数的返回值
1.3.函数的参数
位置参数和关键字参数:位置参数要在关键字参数的前面
参数的默认值:参数名 = 值
不定长参数:加一个*或者两个**
参数类型说明:参数名:类型名,
对函数的返回值进行类型说明: def 函数名(参数列表)-> 返回值类型:
1.4.匿名函数
函数名 = lambda 参数列表:返回值
1.5.三目运算
值1 if 条件语句 else 值2

2.变量的作用域

2.1.变量的作用域
变量在程序中的使用范围
2.2.全局变量
a.申明在函数或者类的外部的变量都是全局变量
b.全局变量的作用域是从申明开始到整个py文件结束,任何位置都可以使用(作用域:从申明开始到文件结束)
2.3.局部变量
a.申明在函数或者类的里面的变量就是局部变量
b.局部变量的作用域是从申明开始到函数结束,任何位置都可以使用(作用域:从申明开始到函数结束)
2.4.关键字global和nonlocal
a.global - 只能在函数中使用,作用是用来在函数中申明一个全局变量
语法:
global 变量名
变量名 = 值
b.nonlocal - 只能在函数中使用
当需要在局部的局部中修改局部变量的值,就使用nonlocal
语法:
nonlocal 变量名
变量名 = 值

3.函数作为变量

python中,申明函数其实就是申明一个类型是function的变量,函数名就是变量名
函数名作为变量除了用来调用函数获取返回值以外,普通变量能做的它都能做
3.1.让一个函数给另外一个函数赋值

# 1.让一个变量给另外一个变量赋值
list1 = [1, 2, 3]  # 申明一个列表变量list1
list2 = list1  # 使用列表变量list1给list2赋值
def func11():  # 申明一个函数变量func11
    print('我是函数')
func22 = func11  # 使用函数变量func11给func22赋值
print(func22())

3.2.将函数作为列表的元素或者字典的值

# 2.将变量作为列表的元素或者字典的值
list1 = [1, 2, 3]  # 申明一个列表变量
list2 = [list2, 100]  # 将列表变量list1作为列表list2的元素
print(list2[0][0])
def func2():  # 申明一个函数func2
    print('我是函数2')
list2 = [func2, 100]  # 将函数变量func2作为list2的元素
print(list2[0]())

3.3.作为函数的参数
将函数1作为实参,传递给函数2,这儿的函数2就是一个高阶函数(实参的高阶函数)

def test(x):
    print(x)
def func3():
    print('我是函数3')  # 申明一个function类型的变量func3
a = 10  # 申明一个int类型的变量a
test(func3)  # 将变量a作为test的实参

3.4.函数作为函数的返回值
返回值是函数的函数,也叫高阶函数(返回值的高阶函数)

# sort(),max() , min(),
'''
def sort(key = None,reverse = false)
key - 确定排序的时候以什么值为标准来排序(默认情况下,以列表的元素大小为标准来排序)
      它需要传一个函数,这个函数必要要有一个参数和一个返回值,这儿的参数是列表中的元素
reverse - 是否降序排序,需要传一个布尔值
list

def test3(char: str):
    """
    根据不同的符号返回不同的功能(函数功能的描述)
    :param char:运算符符号
    :return:不同运算符对应的功能的函数
    """

4.迭代器

迭代器是一个数据类型。也是一种容器
4.1.什么是迭代器(iter)
迭代器是python中容器类的数据类型,可以同时存储多个数据,取迭代器中的数据只能一个一个的取,而且取出来的数据在迭代器中就不存在了

1.将数据转换成迭代器(所有的序列都可以转换成迭代器)
将字符串转换成迭代器
iter1 = iter('asd')
print(iter1)
iter2 = iter([1,2,3,4])
print(iter2)
iter3 = iter({'a':30})
print(iter3)
iter4 = iter({1,2,3,4,5})
print(iter4)

4.2.迭代器数据的来源

a.将其他序列转换成迭代器
b.使用生成式或者生成器产生数据

# 2.获取迭代器中的元素
# a.获取单个元素
# next(迭代器) - 取出迭代器中第一个元素(已经取出来的元素再也回不到迭代器中了)
# iter2.__next__() - 取出迭代器中第一个元素(已经取出来的元素再也回不到迭代器中了)
# b.通过for循环取出迭代器中每个元素
print(next(iter1))
print(next(iter1))
print(next(iter1))
# print(next(iter1)) 当迭代器是空的时候,使用next获取元素,会出现StopIteration
print(iter2.__next__())
print(iter2.__next__())

1.将数据转换成迭代器(所有的序列都可以转换成迭代器)
将字符串转换成迭代器

iter1 = iter('asd')
print(iter1)
iter2 = iter([1,2,3,4])
print(iter2)
iter3 = iter({'a':30})
print(iter3)
iter4 = iter({1,2,3,4,5})
print(iter4)

2.获取迭代器中的元素
a.获取单个元素 next(迭代器) - 取出迭代器中第一个元素(已经取出来的元素再也回不到迭代器中了)
iter2.next() - 取出迭代器中第一个元素(已经取出来的元素再也回不到迭代器中了)
b.通过for循环取出迭代器中每个元素
注意:print(next(iter1)) 当迭代器是空的时候,使用next获取元素,会出现StopIteration

5.生成器

5.1.什么是生成器
生成器就是迭代器,但迭代器不一定是生成器
调用带有yield关键字的函数,拿到的结果就是一个生成器,生成器中元素就是yield关键字后边的值
5.2.生成器怎么产生数据
只要函数中有yield关键字,调用函数不会再执行函数体获取返回值,而是创建一个生成器
当获取生成器的元素的时候,才会执行函数的函数体,执行到yield语句为止,并且将yield后边的值作为结果返回;并且保存当前执行的位置。获取下一个元素的时候,就从上次结束的位置接着往下去执行函数,直到函数结束或者遇到yield为止;如果函数结束了,就出现StopInteration
生成器对应的函数,执行完成遇到yield的次数,决定了生成器能产生的数据的个数

# 生成器产生一个数据
def func1():
    print('asd')
    yield 100
    return 10
# next(func1()) - 执行func1对应的函数体,将yield关键字后边的值作为结果
print('====', next(func1()))

你可能感兴趣的:(day10 - 函数2(总结))