python3的文件读写模式

任何一种语言,文件的读写都是非常常见的。python的文件读写非常简单,仅仅一个函数open(file也可以,但是我不常用)。

先看看官网的解释:

open(file, mode='r', buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)
Open file and return a stream. Raise IOError upon failure.

常用打开模式:

r 只能读
r+ 可读可写,不会创建不存在的文件,从顶部开始写,会覆盖之前此位置的内容
w+ 可读可写,如果文件存在,则覆盖整个文件,不存在则创建
w 只能写,覆盖整个文件,不存在则创建
a 只能写,从文件底部添加内容 不存在则创建
a+ 可读可写 从文件顶部读取内容 从文件底部添加内容 不存在则创建

但是实验发现,这里的r+ 可读可写 不会创建不存在的文件 从顶部开始写 会覆盖之前此位置的内容不完整。

test.txt的原始文件如下:

早上好
您好
how are you?

如果我们在open文件后,没有进行任何读写,则从末尾加入

1 with open('test.txt', mode='r+', encoding='utf-8') as f:
2     f.writelines("北京")

这时文件变成

北京好
您好
how are you?

如果我们在写之前进行了读操作,则会在末尾加入文件

1 with open('test.txt', mode='r+', encoding='utf-8') as f:
2     f.read(1)
3     f.writelines("北京")

这时在文件的末尾加入了北京两个字,与我们读多少没有关系。作用上类似a+模式

早上好
您好
how are you?北京

注意:以r+模式处理文件,容易弄错内容,千万注意

如果以w+方式打开文件,写入文件后,文件被覆盖或重建,样例

1 with open('test.txt', mode='w+', encoding='utf-8') as f:
2     f.write("tianjin")
3     f.flush()
4     print(f.readlines())

得到空[]

with open('test.txt', mode='w+', encoding='utf-8') as f:
    f.writelines("天津")
    f.writelines('山东')
    f.flush()
    f.seek(0)
    print(f.readlines())

需要seek才能读取到刚刚写入的内容。

另外注意 写操作不会自动加入换行符

读的一行末尾会有换行操作,可以用''.strip()去掉换行符

with open('test.txt', mode='r', encoding='utf-8') as f:
    for line in f:
        print(line.strip()) 去掉换行

如果某个文件正在open,就只这时,文件被修改,正在读文件的句柄能读出修改的内容

1 import time
2 with open('test.txt', mode='r', encoding='utf-8') as f:
3     time.sleep(5)
4     for line in f:
5         print(line.strip())

在文件末尾增加文件时,我们的f能读取到最后新增的内容。如果修改已经读取行的内容,若不seek,则读取不到。

这特点能用户增量读取分析日志文件

原文地址:https://www.cnblogs.com/yangshl/p/6285942.html