文件是操作系统为应用程序或者用户提供一种操作硬盘的虚拟单位
强调:
文件是操作系统提供的虚拟单位
应用程序或者用户对文件的读写操作其实都是向操作系统发送指令
文件对应的硬盘空间,如果需要考虑永久保存数据那必须使用文件
路径问题
绝对路径:
win C:acd.txt
linux /a/b/c/d.txt
相对路径:
相对于当前执行文件所在文件夹
1.打开文件
f = open(r'a.txt',mode='rt',encoding='utf-8')
2.读/写文件
a= f.read()
print(a)
f.write()
3.关闭文件
f.close() #向操作系统发送指令,让操作系统关闭打开的文件,回收操作系统资源
上下文管理
with open('a.txt',mode='rt',encoding='UTF-8') as f,
open('a.txt',mode='rt',encoding='UTF-8') as f:
data = f.read()
print(f.readable())
print(f.writable())
print(data)
line=f.readline()
print(line,end='')
print(data)
for line in f:
print(line)
print(f.readlines())
控制文件读写操作的模式
r(默认):只读模式,以该模式打开文件,当文件不存在时则报错,当文件存在时文件指针在文件开头
with open('a.txt',mode='rt',encoding='UTF-8') as f:
pass
w:只写模式,以该模式打开文件,当文件不存在时创建一个空文档,当文件存在时清空文件内容,文件指针在文件开头
with open('a.txt', mode='wt', encoding='UTF-8') as f:
在打开了文件不关闭的情况下,连续的写入,新写的内容总是跟在老内容之后
f.write('你瞅啥
')
f.write('瞅你鸭')
lines = ['11111
', '22222
', '33333
']
f.writelines(lines)
a:只追加写模式,以该模式打开文件,当文件不存在时创建一个空文档,当文件存在时不清空文件内容,文件指针跳到文件末尾
with open('c.txt',mode='at',encoding='UTF-8') as f:
f.writelines('hello
')
复制文件内容
with open('a.txt',mode='rb') as read_f,
open('aa.txt',mode='wb') as write_f:
data=read_f.read()
write_f.write(data)
控制文件读写内容的模式(不能单独使用,必须与r,w,a连用)
t(默认):无论读写都是以字符为单位的,只能操作文本文件,必须指定encoding参数
b:无论读写都是以Bytes为单位的,可以操作所有文件,一定不能指定encoding参数
with open('a.txt',mode='rb') as f:
data=f.read()
print(data,type(data))
方式一:
1.以读的方式打开源文件
2.将文件内容一次性全读入内存,在内存完成修改
3.以写的方式打开源文件,然后将修改后的结果一次性写入源文件
总结:
优点:在文件修改过程中硬盘只有一份数据
缺点:浪费内存
with open('b.txt',mode='rt',encoding='utf-8') as f1:
msg=f1.read()
new_msg=msg.replace('alex','大sb')
with open('b.txt',mode='wt',encoding='utf-8') as f2:
f2.write(new_msg)
方式二:
1.以读的方式打开源文件,以写的方式打开一个临时文件
2.读取源文件的一行内容到内存中,将修改的结果写入临时文件,循环往复直到改
3.删除源文件,将临时文件重命名为源文件名
优点:同一时间在内存中只有文件的一行内容,更节省内容
缺点:在文件修改过程中硬盘只存在两份数据
import os
with open('b.txt','rt',encoding='utf-8') as f1,
open('.b.txt.swap','wt',encoding='utf-8') as f2:
for line in f1:
f2.write(line.replace('大sb','alex'))
os.remove('b.txt')
os.rename('.b.txt.swap','b.txt')