文件打开模式
控制文件读写操作模式
r :只读模式
w : 只写模式
a : 只追加模式
控制文件读写内容模式
t : 读写的内容都是字符串
特点:只适用于文本文件
必须指定encoding参数b : 读写的内容都是bytes类型
特点:一定不要指定encoding参数
使用
r 模式:如果文件不存在则报错,文件存在则将指针跳到文件的开头
with open('c.txt', 'rt', encoding='utf-8') as f:
res = f.read()
w 模式: 如果文件不存在,则创建空文件,如果文件存在,则将指针跳到文件开头,打开的文件不关闭的情况下,新写的内容永远追加再最后
with open('c.txt', 'wt', encoding='utf-8') as f:
f.write("123\n")
f.write("123\n")
f.write("123\n")
a 模式: 如果文件不存在,则创建文件,如果文件存在则追加写,指针跳到文件末尾,如果文件不关闭,新写的内容永远追加在文件最后
with open('c.txt', 'at', encoding='utf-8') as f:
f.write("123\n")
f.write("123\n")
f.write("123\n")
w 模式 与 a 模式的异同
相同点:在打开文件不关闭的情况下,新写的内容会跟在之前写的内容后边
不同点:a 模式打开文件不会清空原有的内容,会将指针直接移动到文件末尾,新写的内容永远追加在最后
r + t 模式
with open('c.txt', 'r+t', encoding='utf-8') as f:
f.write("123")
w + t 模式
with open('c.txt', 'w+t', encoding='utf-8') as f:
res = f.read()
print(res)
a + t 模式
with open('c.txt', 'a+t', encoding='utf-8') as f:
res = f.read()
f.write("123\n")
print(res)
read(2) #读取文件,读取2个字节,不写参数则默认读取全部
# t 模式下读取的是字符,其余都是读取字节数
readline() #读取一行,可指定参数读取一行的几个字符
readlines() #读取每一行内容放入列表中
# f.read()与f.readlines()都是将内容一次性读入内存,如果内容过大会导致内存溢出
#循环读取文件
#方式一:自己控制每次读取的数据的数据量
with open(r'txt.jpg',mode='rb') as f:
while True:
res=f.read(1024) # 1024
if len(res) == 0:
break
print(len(res))
控制文件指针移动
f.seek()
三种模式
0 :永远参照文件开头
1 :参照当前所在位置
2 :参照文件末尾
只有 0 模式可以在 t 下使用
1 和 2 只能用在 b模式上
指针移动的单位都是以bytes/字节为单位
只有一种情况特殊:t 模式下的read(n),n代表的是字符个数
f.seek(n,模式) # n 指的是移动的字节个数
# 0模式 永远参照文件开头
with open('a.text', 'rt', encoding='utf-8') as f:
res = f.seek(5, 0)
print(f.tell()) # 5
# 1 模式 参照当前所在位置
with open('aa.jpg', 'rb') as f:
res = f.seek(5, 1)
res = f.seek(5, 1)
print(f.tell()) # 10
# 2模式 参照文件末尾
with open('a.text', 'rb') as f:
res = f.seek(5, 2)
print(f.tell()) #
文件修改
#方式一:
# 实现思路:将文件内容发一次性全部读入内存,然后在内存中修改完毕后再覆盖写回原文件
# 优点: 在文件修改过程中同一份数据只有一份
# 缺点: 会过多地占用内存
with open('c.txt',mode='rt',encoding='utf-8') as f:
res=f.read()
data=res.replace('aa','123')
print(data)
with open('c.txt',mode='wt',encoding='utf-8') as f1:
f1.write(data)
# 方式二:
import os
# 实现思路:以读的方式打开原文件,以写的方式打开一个临时文件,一行行读取原文件内容,修改完后写入临时文件...,删掉原文件,将临时文件重命名原文件名
# 优点: 不会占用过多的内存
# 缺点: 在文件修改过程中同一份数据存了两份
with open('c.txt', mode='rt', encoding='utf-8') as f, \
open('.c.txt.swap', mode='wt', encoding='utf-8') as f1:
for line in f:
f1.write(line.replace('aa', '123'))
os.remove('c.txt')
os.rename('.c.txt.swap', 'c.txt')