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+ 到底如何操作的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-03用FastAPI掌握Python异步IO:轻松实现高并发网络请求处理
- 2025-01-02封装学习:Python面向对象编程基础教程
- 2024-12-28Python编程基础教程
- 2024-12-27Python编程入门指南
- 2024-12-27Python编程基础
- 2024-12-27Python编程基础教程
- 2024-12-27Python编程基础指南
- 2024-12-24Python编程入门指南
- 2024-12-24Python编程基础入门
- 2024-12-24Python编程基础:变量与数据类型