一.文件打开常用的三总方式
1.文件打开r模式
只读不能写
with open('a.txet','r',encoding='gbk') as a:
# 文件路径 文件打开方式 解码方式 变量名
print(a.read())#一次性读取 ,里面可以填写数字,填了后是读取光标后几个字符
print(a.read())#连续第二次读取会读取空,因为他是一次性读取了就没了
with open('a.txet','r',encoding='gbk') as a:
# 文件路径 文件打开方式 解码方式 变量名
print(a.readline())#一次性读取一行 且会读取到光标移至第二行开头所有这里会读取下来一个\n
print(a.read())#剩下的内容
with open('a.txet','r',encoding='gbk') as a:
# 文件路径 文件打开方式 解码方式 变量名
b = a.readlines()#一次性读取所有,且每行为一个列表的子集
print(b)
为了去除b读取下来的\n,我们可以用strip()
for c in range(len(b)) :
b[c] = b[c].strip()
2.文件打开w模式
只写不能读,且写是先把文件内容清空在写,具有情况作用不是下面的write是在open内的'w'
3.文件打开a模式(只写不能读)
只写不能读,且写是在打文本末尾进行添加
二.文件读写的两种方式
1.文件读取t
读取内容为字符串格式
2.文件读取b
读取内容为二进制格式
3.注意事项
t与b不能单独使用必须和w,a,r联用,如'wt','rt'等等
三.打开两个文件的写法
同时打开两个文件
with open('文件1', 'r') as fr, \
open('文件2', 'r') as fw:
这是竖着的写法,第二排没有缩进没有影响但是为了美观还是缩进对齐会好点
同时打开两个文件
with open('文件1', 'r') as fr, open('文件2', 'r') as fw:
这是横着的写法
四.可读,可写
r+t(也可写成r+): 可读、可写,(指针不做处理默认在开头,光标后开始)
w+t(也可写成w+): 可写、可读(先清空后写)
a+t(也可写成a+): 可追加、可读(指针不做处理默认在结尾,光标后开始写)
可读,可写,二进制
r+b: 可读、可写,(指针不做处理默认在开头,光标后开始)
w+b: 可写、可读(先清空后写)
a+b: 可追加、可读(指针不做处理默认在结尾,光标后开始写)
五.指针
1.seek()
指针移动后的位置,这个位置是字节
不是字符
2.tell()
指针到开头之间的距离
3.truncate()
truncate(n)清除n个字节后的内容
六.修改文件的两种方式
1.第一种
一次性读取所有进行修改,把读取的内容定义成一个变量,修改变量后的值再填写进去
如
import os
with open('37r.txt') as fr, \
open('37r_swap.txt', 'w') as fw:
data = fr.read() # 全部读入内存,如果文件很大,会很卡
data = data.replace('tank', 'tankSB') # 在内存中完成修改
fw.write(data) # 新文件一次性写入原文件内容
# 删除原文件
os.remove('37r.txt')
# 重命名新文件名为原文件名
os.rename('37r_swap.txt', '37r.txt')
print('done...')
2.第二种
逐行读取,然后进行修改
import os
with open('37r.txt') as fr,\
open('37r_swap.txt', 'w') as fw:
# 循环读取文件内容,逐行修改
for line in fr:
line = line.replace('jason', 'jasonSB')
# 新文件写入原文件修改后内容
fw.write(line)
os.remove('37r.txt')
os.rename('37r_swap.txt', '37r.txt')
print('done...')