美文网首页
2018-08-30day9总结

2018-08-30day9总结

作者: 祖国的花朵_3980 | 来源:发表于2018-08-30 17:26 被阅读0次

    一 匿名函数:

    匿名函数本质还是函数,之前函数的所有的内容都适用于它
    1.匿名函数的声明
    函数名 = lambda 参数列表:返回值
    2.说明:
    函数名:变量名
    lambda:声明匿名函数的关键字
    参数列表: 参数名1,参数名2,....
    冒号: 固定写法
    返回值:表达式,表达式的值就是返回值
    3.调用
    匿名函数的调用和普通函数一样
    函数名(实参列表)

     协议个匿名函数计算两个数的和
     声明一个匿名函数
    my_sum = lambda x, y: x+y
    print(type(my_sum))
    下面这个函数和 my_sum = lambda x, y: x+y等价的
    def my_sum(x, y):
        return x+y
    print(type(my_sum))
    

    练习1:写一个匿名函数,获取指定的数字列表指定下标的值的1/2
    匿名函数的参数可以设默认值

    get_value = lambda list1, index=0: list1[index]/2
    

    位置参数

    print(get_value([1, 2, 3, 4, 5], 3))
    print(get_value([1, 2, 3, 4, 5]))
    

    关键字参数

    print(get_value(index=1, list1=[10, 78, 29, 8]))
    

    练习2: 获取一个列表的所有的元素的和和平均值(sum函数可以计算一个序列的和)

    list_operation = lambda list1: (sum(list1), sum(list1)/len(list1))
    
    sum1, average = list_operation([1, 2, 3, 4, 5, 6])
    print(sum1, average)
    

    补充:python中的函数可以有多个返回值的。就是在一个return后返回多个值,多个值之间用逗号隔开

    def list_operation2(list1):
        return sum(list1), sum(list1)/len(list1)   # 最终是将多个返回值放到一个元祖中返回的
    print(list_operation2([1, 2, 3, 4, 5, 6]))   # (21, 3.5)
    

    变量名 = lambda 参数列表:返回值 function
    变量名 = [1, 2, 3] list
    变量名 = 100 int

    二、变量的作用域:

    1.函数的调用过程是一个压栈的过程:
    每次调用一个函数,系统就会在内存区域中的栈区间去开辟空间,保存函数调用过程中产生的数据。
    当函数调用完成后,对应的栈区间会自动销毁
    函数调用时产生的栈区间中保存的数据有:形参、在函数中声明的变量

    def func1(a, b):
        c = 100
        print(a, b, c)
    
    func1(20, 30)
    func1(100, 200)
    

    2.什么是作用域:
    指的就是一个变量能够使用的范围

    3.全局变量和局部变量
    a.
    全局变量:就是声明在函数和类的外面的变量都是全局变量。
    全局变量的作用域: 从声明开始到文件结束(从声明开始到文件结束,任何地方都可以使用)

    a = 100   # 全局变量
    if a > 10:
        b = 20  # 全局变量
    
    # x也是全局变量
    for x in range(10):
        print(x)
        for y in range(10):
            print(y)
    print(a, b)
    print(x, y)
    
    def func2():
        print(x, a, b, y)
    func2()
    

    b.
    局部变量:声明在函数中或者类中的变量就是局部变量
    局部变量的作用域: 从声明开始到函数结束或者是从声明开始到类结束
    注意: 函数的参数是声明在函数中的局部变量

    # x, y, z都是局部变量
    def func3(x1, y1):
        z = 'abc'
        print(x1, y1, z)
    
    # def func4():
    #     print(x1, y1, z)  # 不能再别的函数中使用
    
    func3('a', 'b')
    

    c.
    global关键字:是在函数中声明一个全局变量
    global 变量名
    变量名 = 值

    三、递归函数:

    1.什么是递归函数?
    在函数的函数体中调用函数本身,这样的函数就是递归函数
    2.递归的特点
    while循环能做的事情,递归都可以做

    # 这儿的func1就是递归函数
    def func1():
        print('aaaa')
        func1()
    
    # func1()
    

    3.怎么写递归函数
    第一步: 找临界值 (找到让循环结束的值/找到能够确定函数结果值)
    第二步: 假设函数的功能已经实现的前提下,找关系 (找f(n)和f(n-1)/当次循环和上次循环的关系)
    第三步:根据f(n)和f(n-1)的关系,来通过f(n-1)实现f(n)的效果

    # 1+2+3+4+...+100
    sum1 = 0
    for x in range(101):
        sum1 += x
    print(sum1)
    

    练习: 用递归实现1+2+3...+n

    def my_sum(n):
        # 1.找临界值(在临界值的位置一定要让函数结束)
        if n == 0:
            return 0
        # 2.找关系
    
        my_sum(n) : 1+2+3+...+n-1+n
        my_sum(n-1) : 1+2+3+...+n-1
        my_sum(n) = my_sum(n-1)+n
        """
        # 3.使用f(n-1)实现f(n)的效果
        return my_sum(n-1) + n
    
    print(my_sum(5))
    

    练习:使用递归计算斐波那契数列中1,1,2,3,5,8,13,21...第n个数

    def sequence(n):
        # 1.找临界值
        if n == 1 or n == 2:
            return 1
        # 2.找关系
        """
        sequence(n) = sequence(n-1) + sequence(n-2)
        """
        return sequence(n-1) + sequence(n-2)
    print(sequence(4))
    

    练习:使用递归完成以下的效果:

    n=3


    **

    n=5




    **

    def star(n):
        # 1.找临界值
        if n == 1:
            print('*')
            return  # 临界值的地方让循环结束(函数结束)
    
        """
        star(3):
        ***
        **
        *
        star(2):
        **
        *
        star(n) = 先打印n颗星 + star(n-1)
        """
        print('*'*n)
        star(n-1)
    star(4)
    

    4.在实际开发中,递归是能不用就不要用
    递归需要不断调用函数,开辟空间,消耗内存。

    四、模块和包的使用:

    封装:
    1.函数:对实现某一特定功能的代码段的封装
    2.模块:对变量、函数、类进行封装
    模块:一个py文件就是一个模块

    def multiply(*numbers):
        sum1 = 1
        for item in numbers:
            sum1 *= item
        return sum1
    
    print(multiply(1,2,5))
    

    1.怎么使用其他模块中的内容?
    a.import 模块
    通过模块.内容的形式去使用模块中的内容(能够使用是全局变量、函数、类)

    b.from 模块 import 模块中的内容
    可以直接使用模块中的内容

    c. from 模块 import * ---> 将模块中的所有的内容都导入

    导入系统的math模块
    import math
    print(math.pi)

    导入自定的my_list模块
    import my_list
    a.使用模块中的全局变量
    print(my_list.empty)
    b.使用模块中的函数

    number = my_list.count([1, 2, 3, 4, 6, 1, 8, 9, 1], 1)
    print(number)
    

    2.重命名
    import 模块 as 新名字
    from 模块 import 内容 as 新名字

    import random as RAN
    print(RAN.randint(1, 10))
    
    from datetime import date as DateClass, datetime as TimeClass
    print(DateClass.today())
    print(TimeClass.now())
    

    每个模块都有一个name属性,这个属性的值默认就是当前模块的文件名。
    当当前模块正在被执行(直接在当前这个模块中点了run)的时候,name属性的值是'main'
    在一个模块中,将不希望被其他模块导入的代码写在if name == 'main_'中。
    希望被导入的放到这个if外面。

    建议:函数的声明、类的声明一般写在if的外面,其他的写在if里面。(想要被外部使用的全局变量也可以写在外面)

    if __name__ == '__main__':
    
        a = '^'
        if 'a'<=a<='z' or 'A'<=a<='Z':
            print('是字母')
        else:
            print('不是字母')
    
        x = 90
        10<x<100
    

    相关文章

      网友评论

          本文标题:2018-08-30day9总结

          本文链接:https://www.haomeiwen.com/subject/vtsdwftx.html