Python文件读写 w+ 与 r+ 到底如何操作

2021/11/4 1:10:22

本文主要是介绍Python文件读写 w+ 与 r+ 到底如何操作,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

原文地址:Python中文件读写之 w+ 与 r+ 到底有啥区别?

本文在原文基础上有删改。

r 是只读,只能读不能写,这是很明确的:

f = open("test.txt", 'r', encoding="utf-8") 
f.write("we are heros\n")

data = f.read()
print(data, type(data))
f.close()

这样的话报错是明显的:

io.UnsupportedOperation: not writable

但是变成r+呢,r+是可读写模式:

f = open("test.txt", 'r+', encoding="utf-8")
f.write("we are heros\n")

data = f.read()
print(data, type(data))
f.close()

你试过会发现,什么也没打印出来,但同时也没有报错。到底是什么意思呢?

这是由文件读写机制问题造成的。当一个文件被读或者写一次后,游标指向的是整个文件的末尾。再次读时,是从游标所在的文件末尾开始读,这样的话肯定是什么都读不到了。那写完了接着读的正确姿势是什么呢?

f = open("test.txt", 'r+', encoding="utf-8")  # 文件句柄
f.write("we are heros\n")
f.seek(0)
data = f.read()
print(data, type(data))
f.close()

f.seek(0)使得游标回到文件的开头。这样,读取文件时就是从游标所在的文件开头位置读取了。

那么r+与w+又有啥区别呢?不能简单的理解为读写都可,它们在细节之处还是略有不同!

r+:

  • 先读后写,会在原有文本内容的后面添加写入内容。 因为读完时游标在文件最末尾。
  • 先写后读,是从头开始覆盖式写入,实际写多少内容,就覆盖多少内容。写入完成后,游标停留在写完的位置而不是文件的末尾,此时再进行读取,可以读出未被新内容覆盖的文档内容。

w+:

  • 先写后读,写完后游标就停留在文档的末尾,马上读的话什么内容都读取不到。应使用f.seek(0)让游标回到初始位置后,再开始读取。
  • 先读的话是读不出任何东西的,因为w+也是纯粹的覆盖写,在未使用写操作前,无论之前该文件里有什么内容,已经被完全置空,是空白的。所以只能先写后读。


这篇关于Python文件读写 w+ 与 r+ 到底如何操作的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程