day12、文件操作 2019-01-08
一、复习
1.递归函数(了解)
a.找临界值
b.找关系( f(n) 和 f(n-1) )
c.用 f(n-1) 实现 f(n)
(能使用循环就不使用递归;因为递归性能低,会消耗大量内存和 cpu 资源)
2.模块
模块就是 py 文件
import 模块
from 模块 import 内容
import 模块 as ...
from 模块 import 内容 as ...
3.迭代器和生成器
迭代器: iter ;将其他序列转换成迭代器;
取元素: next() , for-in;
生成器:调用一个带有 yield 关键字的函数。
例如:
if __name__ == '__main__':
# 写在这个函数里面的内容不会被导入
pass
def func1():
for i in range(10):
yield i
print(next(func1())) # 结果为:0
print(next(func1())) # 结果为:0
num1 = func1()
print(next(num1)) # 结果为:0
print(next(num1)) # 结果为:1
运行效果:
0
0
0
1
二、生成式
1.什么是生成式
生成式就是生成器的一种特殊写法(固定写法)
2.写法
a.
生成器 = (表达式 for 变量 in 序列)
功能:让变量去序列中取值,每取一个值就将对应表达式的值作为生成器的元素返回一次。
def 函数名():
for 变量 in 序列:
yield 表达式
b.
生成器 = (表达式 for 变量 in 序列 if 条件语句)
def 函数名():
for 变量 in 序列:
if 条件语句:
yield 表达式
例如:
gen1 = (i * 2 for i in range(5))
print(gen1)
print(next(gen1)) # 结果为:0
print(next(gen1)) # 结果为:2
print(next(gen1)) # 结果为:4
def func1():
"""这个是生成式展开成生成器的写法"""
for i in 'adc':
yield i * 2
gen2 = ((value, key) for key, value in {'name': '小明', 'age': 20, 'tel': 666666}.items())
print(next(gen2)) # 结果为:('小明', 'name')
print(next(gen2)) # 结果为:(20, 'age')
def func2():
"""这个是生成式展开成生成器的写法"""
for key, value in {'name': '小明', 'age': 20}.items():
yield value, key
运行效果:
0
2
4
('小明', 'name')
(20, 'age')
3.将迭代器、生成器转换成其它序列
例如:
list1 = list(gen2) # 转换后,生成器里面就没有元素了
print(list1) # 结果为:[(666666, 'tel')]
# print(list1) # 报错。(stopiteration)
# [生成式] -----直接将生成式对应的生成器转换成列表
list2 = [(value, key) for key, value in {'name': '小明', 'age': 20, 'tel': 666666}.items()]
print(list2)
# 练习:交换字典中的 key 和 value 的值
dict1 = {'a': 1, 'd': 1, 'c': 2}
result = dict((x, y) for y, x in dict1.items())
print(result)
运行效果:
[(666666, 'tel')]
[('小明', 'name'), (20, 'age'), (666666, 'tel')]
{1: 'd', 2: 'c'}
三、文件操作
1.数据本地化和数据持久化
将数据以文件的形式存到计算机硬盘中(程序中保存的数据,当程序结束时会自动销毁)
2.怎么做数据持久化(怎么将程序中的数据和本地文件中的数据关联)
文件读(获取文件中的内容)写(将数据添加到文件中)操作:
a.文件操作的流程为(文件操作不关乎语言):打开文件 --> 文件操作(读/写) --> 关闭文件
3.打开文件
open(file, mode = 'r', encoding = None) -----以指定的模式打开指定的文件,并返回被打开的文件对象
说明:
file: -----格式是字符串,需要打开的文件的路径。
绝对路径(了解):就是文件在电脑上的完全路径。
相对路径:相对当前代码文件对应的目录来确定路径(
' 紫极天下.txt '
'./紫极天下.txt '
'../紫极天下.txt ' -----打开当前目录的上层目录)。
mode: -----格式是字符串,文件的打开方式。
'r' --> 以只读的形式打开 (默认)
'rb/br' --> 以只读的形式打开,二进制
'w' --> 以只写的方式打开(会覆盖)
'a' --> 以只写的方式打开(打开在写的时候为 覆盖 )
'wb/bw' --> 以只写的形式打开,二进制
'+' --> 以读、写的方式打开
注意:当以读的方式打开一个不存在的文件,程序报错;
当以写的方式打开一个不存在的文件,不会报错,并且自动创建这个文件。
encoding: -----格式是字符串,文件的编码方式。
utf-8:支持所有的语言
gbk:只支持英语
注意:a.读和写时对应的文字编码方式,要保持一致。
文件是以什么编码方式保存,就以什么编码方式打开,
b.非文本文件不能设置编码方式。例如:图片文件、视频文件、可执行文件等。
c.给它传值的时候,要使用关键字参数。
d.以二进制形式打开文件时,不能设置 encoding 。
一、打开文件:
a.打开文件,文件路径为绝对路径:
例如:
# open('C:\Users\Administrator\PycharmProjects\untitled1\day12.file 1.8\紫极天下.txt')
# b.打开当前目录下的文件:
open('紫极天下.txt')
open('./紫极天下.txt') # 与上面的语句作用一样。
打开当前目录下的子目录里面的文件: '子目录/文件名' or './子目录/文件名'
open('files/test.txt')
open('./files/test.txt') # 与上面的语句作用一样。
open('././code/hhh.txt') # 打开当前目录的上层目录里的文件。
二、打开方式:
例如:
txt1 = open('././code/hhh.txt', 'r', encoding='utf-8')
f = txt1.read()
f1 = txt1.readline()
print(f)
运行效果:
1
2
3
4
4.操作文件
a.读操作:
文件对象.read() -----读整个文件的内容
文件对象.readline() -----读文件的一行内容
5.关闭文件
文件对象.close()
6.文件操作的简写
with open(f1, mode, encoding) as 文件对象
文件操作代码
练习:读文件中 的内容,一行一行的读,读完为止
while True:
f1 = txt1.readline()
print(f)
if not f1:
break
运行效果:
1
2
3
4
如果文件进行写操作,那么文件必须以写的方式打开。
w -----用新的内容覆盖原内容
a -----在原文件的末尾添加新的内容
例如:
f = open('././code/hhh.txt', 'a', encoding='utf-8')
f.write('halo')
f = open('././code/hhh.txt', 'w', encoding='utf-8')
f.write('hellow')
运行效果:
1234halo
hellow
图片下载过程:请求图片二进制数据,将二进制数据写入本地文件中
import requests
requests = requests.get('网络地址')
f = open('图片名字.jpg', 'wb')
关闭打开文件
f.close()
练习:用一个变量来保存当前文件执行的次数:第一次执行 py 文件的时候打印1,第二次执行打印2···
程序中需要这个数据的时候,就从文件中将这个数据读出来。
对数据进行了修改之后,再把最新的数据保存到文件中。
# 读文件
with open('./code./num.txt', encoding='utf-8') as f:
num1 = int(f.read())
# 改数据
num1 += 1
# 写入
with open('./code./hhh.txt', 'w', encoding='utf-8') as f:
f.write(str(num1))
# 显示数据
print(num1)
运行效果:
1