知识回顾
1.匿名函数
变量 = lambda 参数列表:返回值
参数列表:变量名1 , 变量名2, ...
函数体是一条语句,并且这条语句是有结果的
匿名函数也是函数
2.变量的作用域
全局变量:没有声明在函数或者类中的变量。从声明开始到文件结束,任何位置都能用
局部变量:声明在函数或者类中的变量。从声明开始到函数、类结束
global:在函数中声明一个全局变量/想要在函数中修改一个全局变量的值
nonlocal:想要在局部的局部去修改一个局部变量的值
3.函数作为变量
声明函数就是在声明一个类型是function的变量。普通变量能做的事情,函数变量都能做
函数名 --> 一个函数
函数名() --> 调用函数,拿到的是函数的返回值
函数作为参数 --> 闭包
函数作为返回 --> 装饰器
4.调用过程
函数的调用过程是一个压栈的过程
调用函数的时候系统会自动在栈区间开辟空间存储数据(函数的参数,函数的中声明的变量),调用结束后会自动销毁
5.递归函数
自己调用自己的函数
循环能做的递归都可以做,但是能用循环的就不要用递归
三个步骤:
a.找临界值,在这要让函数结束
b.找出f(n) 和 f(n-1)的关系
c.使用f(n-1)去实现f(n)的功能
模块的使用
1.导入模块
python中一个py文件就是一个模块。
可以通过import或者from-import在一个模块中去使用另一个模块中的内容
import 模块名 --> 将模块中所有的内容都导入,并且可以在当前模块中通过‘模块名.’的方式去模块中的所有全局变量
from 模块名 import 变量1, 变量2,... --> 将模块中所有的内容都导入。但是只能使用import后面的变量
from 模块名 import * --> 将模块中所有的内容都导入,可以直接使用模块中的所有全局变量
代码执行到import的时候,会将import后面的模块的内容执行一遍
# import test1
# # 使用test1中的整型变量test_a
# print(test1.test_a)
#
# # 使用test1中的函数test1_func1
# test1.test1_func1()
# from test1 import test_a, test1_func1
# from test1 import *
# print(test_a)
# test1_func1()
2.重命名
import 模块名 as 模块的新名字 --> 给模块重命名,使用模块的时候用新的名字来使用
from 模块名 import 变量名1 as 新名1,变量名2 as 新名2,变量名3 --> 给部分变量重新命名
# import test1 as TS
# print(TS.name)
name = 'p'
from test1 import name as test1_name, test1_func1 as func1, test_a
print(name) #使用当前模块的name变量
print(test1_name) #使用test1中的name
3.import:可以检查被导入的内容之前是否已经导入过,如果导入过,不会再重复导入
# 导入多次,但是只执行一次。多种导入的效果可以同时生效
import test1
# import test1
from test1 import test_a as AA
print(test1.test_a)
选择性导入(阻止导入)
1.
if __name__ == '__main__':
不希望被别的模块导入执行的代码写在这
说明:
if __name__ == '__main__': --> 固定写法
代码块 --> 直接执行当前模块,代码会被执行。如果在别的模块中被导入,代码块不会执行
2.每一个模块都有一个__name__属性,这个属性的默认值是当前模块对应的py文件的文件名
当 当前模块 正在被执行(执行)的时候,系统会自动将模块的__name__属性变成‘__main__’
import test1
print(test1.name)
3.什么时候使用模块
将具有相同的功能的函数和数据封装到一起
迭代器
1.什么是迭代器(iter)
迭代器是python中一种容器类的数据类型。属于序列。没有具体的字面量,可以将其他的序列转换成迭代器
2.迭代器的特点
只能通过next方法去一个一个的按顺序获取迭代器中的元素,取出后迭代器中就不存在这个元素了
iter1 = iter('abcd')
print(iter1)
print(next(iter1))
3.遍历迭代器
print('________')
for x in iter1:
print(x)
"""
next(迭代器)
迭代器.__next__()
"""
print('--------')
iter2 = iter({'a': 1, 'b': 2})
for x in iter2:
print(x)
生成式和生成器
1.什么是生成器
生成器就是迭代器,但是迭代器不一定是生成器
生成式就是生成器的一种特殊形式:(变量 for 变量 in 序列)
产生一个生成器,生成器中可以生成的数据是数字0~4(每个元素是数字)
ge1 = (x for x in range(5))
print(ge1)
print(next(ge1))
print(next(ge1))
print('-------')
for item in ge1:
print(item)
print('---------')
ge2 = (x * 2 for x in range(5))
for item in ge2:
print(item)
print('---------')
ge3 = ([x, x * 2] for x in 'abc')
for item in ge3:
print(item)
print('---------')
ge2 = (x for x in range(5) if x % 2)
for item in ge2:
print(item)
2.生成器就是函数体中有yield关键字的函数
--> (只要函数中有yield,那么调用这个函数不再是执行函数体并且获取返回值,而是产生一个生成器)
通过next获取生成器的元素的时候,会去执行生成器对应的函数体,执行到yield为止,并且将yield后面的值作为返回值(元素值)
然后保存当前结束的位置,下一次获取元素的时候会接着上次结束的位置往后执行,执行到yield....
生成器可以当成序列来使用
def func1(n):
for x in range(n + 1):
yield x
print('__________')
ge3 = func1(5)
print(ge3)
print('__________')
# print(next(ge3))
print(next(ge3))
print(next(ge3))
print(next(ge3))
文件的读和写
使用本地文件可以做数据的持久化(本地化) --> 数据库文件,txt,json,plist,二进制文件
1.文件操作 -- 读写操作
读 --> 取出文件中的数据
写 --> 将数据写到文件中
所有文件操作的过程:打开文件 --> 操作文件 --> 关闭文件
2.打开文件和关闭文件
open(file, mode='r')
a.file --> 文件路径(必须传参),觉得需要打开的是哪个文件
决定路径(不推荐使用)
相对路径:./相对路径 (相对路径是相对当前py文件对应的文件夹)
./ --> 当前文件夹
../ --> 当前文件夹的上层文件夹
.../ --> 当前文件夹的上层文件夹的上层文件夹
b.
方式 | 说明 |
---|---|
mode | 文件打开方式(不同的操作对应不同的打开方式) |
'r' | 以只读的形式打开文件 |
'rb'/'br' | 读操作,读出来的数据是二进制形式的数据 |
'w' | 以写的形式打开文件 |
'bw'/'wb' | 写操作,将二进制数据写入文件 |
'a' | 写操作,追加 |
c.
编码 | 说明 |
---|---|
encoding | 文本文件的编码方式 |
utf-8 | 几乎支持所有的语言文字 |
gbk | 只支持英文 |
d.
open函数的返回值,就是被打开的文件对象
关闭文件:文件对象.close()
文件的读操作
1.打开文件
f1 = open('./test.txt', 'r', encoding='utf-8')
2.读文件中的内容
操作方法 | 说明 |
---|---|
文件对象.read() | 从文件的读写位置读到文件结束,返回读到的结果 |
文件对象.readline() | 读一行 |
文件对象.readlines() | 返回一个列表,列表的元素是文件中每一行的内容 |
content = f1.read()
print(type(content), content)
print('---:', f1.read())
# content = f1.readline()
# print(type(content), content)
3.关闭文件
f1.close()
文件的写操作
1.打开文件
操作方式 | 说明 |
---|---|
'w' | 将字符串写入文件中,完全覆盖文件原来的内容 |
'wb'/'bw' | 将二进制写入文件中,完全覆盖文件原来的内容 |
'a' | 追加 |
f2 = open('./test.txt', 'w', encoding='utf-8')
2.写入文件
f2.write(content + 'hello world')