Python中的读写机制 | r+与W有什么区别?

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.read()两次的话,第二次什么都不会读到的原因是相同的。

如何写完了接着读呢

例子:

 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)

使得类指针的东西回到文件的开头,然后又从头开始读即可。

配合f.tell()使用

英文及字符返回的是那个类指针的位置(也就是字符的个数),但是中文的话是字符个数*3,具体原因不清楚

r+与w+啥区别呢,不能简单的理解为读写都可,细节之处略有不同

r+:先读后写的话是在原有文本后添加

w+:为先写后读,先写完后使用f.seek(0)回到初始位置然后开始读

r和w的区别

r 必须已经存在这个文件了而 w 时文件可以有也可以没有,if有被覆盖,else没有则创建一个(慎用),r+的写也是覆盖的!

参考博客:https://www.cnblogs.com/xxpythonxx/p/12098943.html

posted @ 2021-05-20 14:14  poowicat  阅读(427)  评论(0编辑  收藏  举报