复习:
1.函数就是对实现某一特定功能的代码块的封装
2.函数的声明:
def 函数名(新参列表):
函数的说明文档
函数体
3.函数的函数体只是在函数调用的时候才会执行!!!
4.函数的调用
函数名(实参列表)
5.函数的调用过程
!!!!重要!!!
a.回到函数的声明位置
b.用实参给形参赋值---->(传参-一定要保证每一个参数都要有值)
c.执行函数体
d.将返回值返回
e.回到函数调用的位置(这个时候函数调用表达式的结果就是返回值)
6.位置参数和关键字
7.参数可以有默认值(可以对参数的类型进行说明)
8.不定个数的参数,在参数名前加*
9.返回值
Python中所有的函数都有返回值。看一个函数的返回值:看函数体在执行的过程中,有没有执行到return语句,如果有函数的返回值就是return后面的值。没有就是None
return关键字:确定返回值:结束函数
10.只要函数的功能产生了新的数据,就把新的数据返回。
def download(url):
例如:通过网络下载数据(函数功能的描述)
:param url ;str,下载数据的地址
:return:None/下载到的数据
pass
判断是否有网
如果没有网络
return
下载数据
解析数据
存储数据
1.匿名函数:
匿名函数本质还是函数,之前函数的所有的内容都适用于它
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))
调用匿名函数
result = my_sum(10, 20)
print(result)
练习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
2.作用域
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')
局部变量只能在声明变量的那个函数中使用,不能在函数外面使用
print(y1)
print(z)
"""
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)
nonlocal 不声明局部变量
def func5():
局部变量
nn = 10
函数中可以声明函数
def func6():
nonlocal nn # 在局部的局部中修改局部变量的值
nn = 20
print('func6',nn)
func6()
print('func5', nn)
func5()
print(nn)
def func():
a = []
for i in range(5):
a.append(lambda x: x*i)
return a
aa = func()
print(aa[0](2), aa[2](2), aa[3](2))
3.递归函数:
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))
my_sum(5) n=5 return 1+2+3+4+5 = 15
my_sum(4) n=4 return 1+2+3+4
my_sum(3) n=3 return 1+2+3
my_sum(2) n=2 return 1+2
my_sum(1) n=1 return 0+1
my_sum(0) n=0 return 0
练习:使用递归计算斐波那契数列中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.在实际开发中,递归是能不用就不要用
递归需要不断调用函数,开辟空间,消耗内存。
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 * ---> 将模块中的所有的内容都导入
a
导入系统的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)
b.
from my_list import count, empty
print(count([23, 3, 45, 67, 8, 12, 5, 8, 3], 8))
print(empty)
c.
from math import *
print(pi)
print(sqrt(4))
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里面。(想要被外部使用的全局变量也可以写在外面)
import my_model
from my_model import func1
print(func1())
print('my_model',my_model.__name__)
print('01-模块:',__name__)
if __name__ == '__main__':
a = '^'
if 'a'<=a<='z' or 'A'<=a<='Z':
print('是字母')
else:
print('不是字母')
x = 90
10<x<100
指定文件:名为:my_list.py
empty = []
def count(list1, item):
统计指定列表中指定元素的个数
:param list1: 指定的列表
:param item: 指定的元素
:return: 个数
num = 0
for x in list1:
if x == item:
num += 1
return num
print('abc')
print(empty)
print(count(['a', 12, 'b', 'a'], 'a'))
指定文件:my_model.py
a = 10
def func1():
print('good!')
print(__name__)
将不希望被别的模块导入(执行)的代码放到模块的这个if语句中
if __name__ == '__main__':
print('!!', a)
for x in range(10):
print('!!', x)
网友评论