2018-08-30 day09函数总结

2018-08-30  本文已影响0人  汤姆猫是只疯猫
1匿名函数

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

#声明一个匿名函数
my_sum = lambda x,y:x+y
print(type(my_sum))
print(type(my_sum))
#调用匿名函数
result = my_sum(10,20)
print(result)
输出:
<class 'function'>
30

练习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.0
0.5
39.0

练习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)
输出:
21 3.5

补充: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)
2.变量的作用域

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

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

2.什么是作用域
指的是一个变量能够使用的范围
3.全局变量和局部变量
a.全局变量:就是声明在函数和类的外面的变量都是全局变量
全局变量的作用域:从声明开始到文件结束(从声明开始到文件结束,任何地方都可以用)

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

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

def func3():
      z = 'abc'
      print(x1,y1,z)
func3('a','b')
输出:
a b abc

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

#全局变量
num1 = 100
#全局变量
num2 = 10
def func4():
      #局部变量
      num1 = 200
      print(num1)  #如果全局变量和局部变量同名,那局部变量的作用域内使用的是局部变量的值
#想要在局部区域内修改全局变量的值
    global num2  # 说明从这句开始后面的num2都是全局变量
    num2 = 199
    print(num2)

    global num3  # 直接在函数中声明一个全局变量。这个变量在外面只有函数调用后才能使用
    num3 = 'aaa'

func4()
print(num1)
print(num2)
print(num3)
输出:
200
199
100
199
aaa

nonlocal 不声明局部变量

def func5():
    # 局部变量
    nn = 10
    # 函数中可以声明函数
    def func6():
        nonlocal nn  # 在局部的局部中修改局部变量的值
        nn = 20
        print('func6',nn)
    func6()
    print('func5', nn)
func5()
输出:
func6 20
func5 20
3.递归函数

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

#func1就是递归函数
def func1():
      print('asd')
      func1()
func1

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

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

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

def fei(n):
    if n == 1 or n ==2:
        return 1
    return fei(n-1) + fei(n-2)
print(fei(3))
输出:
2

使用递归完成以下的效果


输出效果
def star(n):
    if n == 1:

        print('*')
        return
    print('*'*n)
    star(n-1)
star(3)
在实际开发中,递归能不使用就不用
模块和包的使用

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

def multipy(*numbers):
    sum1 = 1
    for item in numbers:
        sum1 *= item
    return sum1
print(multipy(1,2,5))
输出:
10

1.怎么使用其他模块的内容
a. import 模块
通过模块.内容的形式去使用模块中的内容(能够使用的是全局变量,函数,类)
b. from 模块 import 模块中的内容
可以直接使用模块中的内容
c.from 模块 import * ---->

#导入自定义的my_list模块
import my_list
#使用模块中的全局变量
print(my_list.empty)
num = my_list.count([1,2,3,4,3,1,3],3)
print(num)
from my_list import count
print(count([1,2,3,4,3,1,3],3))
或者是
from math import *
print(pi)
print(sqrt(4))
输出:
3
3.141592653589793
2.0

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

import random as RAN
print(RAN.randint(1,10))

from datetime import date as DateClass
print(DateClass.today())
输出:
10
2018-08-30

每个模块都有一个name属性,这个属性的值默认就是当前模块的文件名
当当前模块正在被执行(直接在当前这个模块中点了run)的时候name属性的值是'main'
在一个模块中将不希望被其他模块导入的代码写在if name=='main'中
建议:函数的声明,类的声明一般写在if的外面,其他的写在if 的里面(想要被外部使用的全局变量也可以写在外面)

上一篇下一篇

猜你喜欢

热点阅读