一、生成式
1.什么是生成式
生成式就是生成器的一种特殊写法
2.写法
a.
生成器 = (表达式 for 变量 in 序列)
让变量取序列中取值,每取一个值就将对应的表达式的值作为生成器的元素
相当于:
def 函数名():
for 变量 in 序列:
yield 表达式
b.
生成器 = (表达式 for 变量 in 序列 if 条件语句)
相当于:
def 函数名():
for 变量 in 序列:
if 条件语句:
yield 表达式
gen1 = (x for x in 'cc520')
print(gen1)
print(next(gen1))
print(next(gen1))
print(next(gen1))
print(next(gen1))
print(next(gen1))
# 相当于
def func1():
for x in 'cc520':
yield x * 2
# gen1 = func1
print(func1())
# 带if的生成式
gen2 = (y for y in range(10) if y & 1)
print(next(gen2)) # 1
print(next(gen2)) # 3
print(next(gen2)) # 5
3.迭代器生成器转换成其他序列
list1 = list(生成式) --> 直接将生成式对应的生成器转换成列表
list1 = list(gen2)
print(list1) # 因为在上面gen2已经被取走了1,3,5,所以打印的列表结果为[7,9]
# print(next(gen2)) False StopIteration,因为gen2已经被取完了
练习:将字典的键值对的键和值位置互换(产生新的字典和原字典中改变)
dict1 = {'a': 'cc', 'b': 520, 'c': 1314}
result = dict((x, y) for y, x in dict1.items())
print(result)
在原字典中改变
def change(dict2 : dict):
for key in dict2.copy():
value = dict2.pop(key)
dict2[value] = key
return dict2
print(change({'a': 'cc', 'b': 520}))
二、文件操作
1.数据本地化和数据持久化
将数据以文件额形式存到计算机硬盘中(程序中保存的数据,当程序运行结束会自动销毁)
2.怎么做数据持久化(怎么将程序中的数据和本地文件中的数据关联)
文件读写操作 -- 读(获取文件中的内容),写(将数据添加到文件中)
a.文件操作的基本流程:打开文件 —> 文件操作(读/写) -> 关闭文件
3.打开文件
open(file,mode='r',encoding= None)-> 以指定的模式打开指定文件,并且返回被打开的文件对象
说明:
-
file - 字符串,需要打开的文件路径
绝对路径:文件在电脑上全路径
相对路径:相对当前代码文件对应的目录来确定的路径
'致橡树.txt' --> 当前目录下面的致橡树.txt
'./致橡树.txt' --> 当前目录下面的致橡树.txt
../ --> 代表当前目录的上层目录 -
mode - 字符串,文件的打开方式(打开的方式不同,数据类型不同)
① r -> 以读的形式打开,文本(文件默认的打开方式)
②w -> 以写的形式打开(覆盖),文本
③rb/br -> 以读的形式打开,二进制
④ wb/bw -> 以读的形式打开(覆盖),二进制
⑤a -> 以写的形式打开(追加),文本
⑥+ -> 以读写的形式打开注意:当以读的方式打开一个不存在的文件会报错FileNotFindError 但是以写的方式打开一个不存在的文件,不会报错,还会自动创建一个文件
-
encoding - 字符串,文字编码方式
utf-8(默认):支持所有语言
gbk:只支持英文注意:a.读和写对应的编码要保持一致 b.非文本文件不能设置编码方式,例如:图片、视频可执行文件(.exe) c.给它传值的时候要使用关键字参数 d.以二进制的形式打开文件,不能设置encoding
4.操作文件
a.读操作
文件对象.read() - 获取指定文件中的内容
5.关闭文件
文件对象.close()
6.文件操作的简写 - 打开文件,操作完成后自动关闭文件
- with open(file,mode='r',encoding= None)as 文件对象
文件操作代码
# ==========================打开文件================================
# 1.打开当前目录下的文件
open('致橡树.txt')
open('./致橡树.txt')
# 2.打开当前目录下的文件的子文件:目录/子目录/文件名
# 3.打开不同级(非相同目录)的文件:../ --> 代表当前目录的上层目录
# 4.若想要打开更上层目录的文件,就在前面加‘.’
# ============================打开方式==========================
f = open('致橡树.txt', encoding='utf-8')
# ========================3.读操作================================
# 以‘r’方式打开文件,获取文件对象
f = open('致橡树.txt', encoding='utf-8')
print(f.read())
# 以‘rb’的方式打开文件
f = open('致橡树.txt', 'rb')
print(f.read())
# 读一行
f1 = open('致橡树.txt', encoding='utf-8')
line1 = f1.readline()
print(line1)
# 练习:读文件中的内容,一行一行的读,读完为止:
f2 = open('致橡树.txt', encoding='utf-8')
while True:
line1 = f2.readline()
if not line1:
break
print(line1)
# =========================写操作=============================
如果需要文件进行写操作,那么文件必须是以写的方式打开
w --> 用新的内容覆盖原内容
a --> 在原文件末尾添加新的内容
f = open('致橡树.txt', 'a', encoding='utf-8')
f.write('木子兮陈儿')
程序中需要这个数据的时候就从文件中将这个数据读出来
对数据进行修改之后,再将最新的数据保存到文件中
练习:用一个变量来保存当前文件执行的次数:第一次执行py文件的时候打印1,第二次执行打印2
# 将数据从文件中读出来
with open('cc.txt', encoding='utf-8') as f3:
num = int(f3.read())
# 修改数据
num += 1
# 将新的数据写入文件中
with open('cc.txt', 'w', encoding='utf-8') as f3:
f3.write(str(num))
# 显示数据
print(num)
网友评论