Python⽂件读写w+和r+区别解析
其实r是只读,只能读不能写,这是很明确的,但是r+是可读写,变成r+后还没太明⽩到底加了什么,还是照样写不了,有没
有这样的体验呢,如下代码,只读时
f=open("",'r',encoding="utf-8")#⽂件句柄
("weareherosn")
data=()
print(data,type(data))
()
这样的话报错是明显的:ortedOperation:notwritable,不可写应都能理解,但是变成r+呢
f=open("",'r+',encoding="utf-8")#⽂件句柄
("weareherosn")
data=()
print(data,type(data))
()
你试过会发现,什么也没打印出来,同时注意也没有报错。到底是什么意思呢?
其实是由于读写机制的问题,当⼀个⽂件被读或者写⼀次后,⽂件中类指针的东西指向的是整个⽂件的末尾,再次读时从末尾
开始读的话肯定是什么都
读不到了,所以会出现这样的问题,和连续()两次的话,第⼆次什么都不会读到的原因是相同的。那如何写完了接着读
呢,见代码
f=open("",'r+',encoding="utf-8")#⽂件句柄
("weareherosn")
(0)
data=()
print(data,type(data))
()
加上(0)使得类指针的东西回到⽂件的开头然后从头开始读即可。配合()使⽤,英⽂及字符返回的是那个类指针的位
置(也就是字符个数),但是中⽂的话是字符个数*3,具体原因还得请⼤侠给讲讲。
r+与w+啥区别呢,不能简单的理解为读写都可,细节之处略有不同!
r+:先读后写的话是在原有⽂本后添加,因为读完后类指针已经在最末尾了,如果是先写后读的话,是从头开始覆盖式写
(如只修改了前⾯的字符,后⾯字符是不会被删掉的),类指针停留在写完的末尾,不是⽂档末尾,可以读出未被覆盖
写的部分;
w+:为先写后读,先写完后使⽤(0)回到初始位置然后开始读,如果先读的话是读不出任何东西的,因为w+也是纯
粹的覆盖写,在未使⽤写操作前⽂档是完全空⽩的,⽆论之前该⽂件⾥有什么。so,只能先写后读。
r和w的区别,r必须已经存在这个⽂件了⽽w时⽂件可以有也可以没有,if有被覆盖,el没有则创建⼀个(慎
⽤),r+的写也是覆盖的!
以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。
本文发布于:2022-11-16 05:27:36,感谢您对本站的认可!
本文链接:http://www.wtabcd.cn/fanwen/fan/88/29173.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |