python中的文件处理
文件的打开方式
r ,只读模式【默认模式,文件必须存在,不存在则抛出异常】
w,只写模式【不可读;不存在则创建;存在则清空内容】
a, 之追加写模式【不可读;不存在则创建;存在则只追加内容】
读取
file = open('test',encoding='UTF-8') # 以UTF-8的方式打开文件
data = file.read() #
print(data)
file.close()
- open 打开文件
- read 读取文件
- close 关闭数据流
- readable() 是否可读
- readline() 读一行
- readlines() 将读取的每一行内容放入列表返回
- closed() 判断是否关闭
- encoding 显示编码符号
写入
file = open('test','a',encoding='UTF-8') #以追加模式打开文件
file.write('this is a test')
file.close()
- writable() 是否可写
- write() 写入
- writeLines([‘3213\n’,‘321312\n’]) 写一个列表行
with 方式打开
with open('test','r',encoding='UTF-8') as f:
data = f.read()
print(data)
wtih打开时不需要再写file.close()
以字节的方式处理文件
对于非文本文件,我们只能使用b模式,"b"表示以字节的方式操作(而所有文件也都是以字节的形式存储的,使用这种模式无需考虑文本文件的字符编码、图片文件的jgp格式、视频文件的avi格式)
rb
wb
ab
注:以b方式打开时,读取到的内容是字节类型,写入时也需要提供字节类型,不能指定编码
- 读取
f = open('ohterF.py','rb')
data = f.read()
print(data.decode('utf-8'))
- 写入
f = open('ohterF.py','ab')
f.write("\n杨".encode('utf-8'))
f.write(bytes('432432水',encoding='UTF-8'))
flush 释放缓冲区中的数据到硬盘中(通常用于保存)
文件光标操作
- f.tell() 查看光标位置
- f.seek(0) 指定光标的位置,seek有三种移动方式0,1,2,其中1和2必须在b模式下进行,但无论哪种模式,都是以bytes为单位移动的
seek(3,1) 基于相对位置移动
seek(3,0) 基于绝对位置移动
seek(-3,2) 基于文件末尾位置移动(倒序时必须为负数)
- f.truncate(10) 截取0-10给字节
- read(3):
- 文件打开方式为文本模式时,代表读取3个字符
- 文件打开方式为b模式时,代表读取3个字节
补充关于 newline
f.open(‘a.py’,‘r’,encoding=‘UTF-8’,newline=’’)
python再读取时会默认把所有的换行符转化为\n,而windows中是\r\n,newline=’'是告诉python不要执行默认转化。