在一个文件的末尾追加数据是很常用的。在使用过程中应该都比较熟悉不会出现什么错误。但是往一个文件头部插入数据可能或多或少会碰到一些问题。
看似正确的错误代码
很多代码看似正确,但是其实都是错的。一起来看下这些代码
1、看似正确的错误代码1
1
2
3
|
with open(path, "r+") as f: f.seek(0) f.write(data) |
确实是从头写了,而且有些原有数据确实在,但是数据有问题。。。。
因为”r+”方式写文件操作没有插入的语义,只有写文件的含义,原来位置如果有数据,不会后移的,是覆盖掉了。。。。所以,你可能会看到一些老的数据。不仔细辨别可能就天真地以为成功了。。。
2、看似正确的错误代码2
1
2
3
4
5
|
with open(path, "w+") as f: old = f.read() f.seek(0) f.write(data) f.write(old) |
你读取到的数据永远为空。。。。
因为”w+”的含义就是截取长度为0然后写入文件。
3、看似正确的错误代码3
1
2
3
4
5
|
with open(path, "a+") as f: old = f.read() #f.truncate(0) #取消掉注释成正确代码 f.seek(0) f.write(data) |
写入的数据永远出现在文件末尾。。。。。
要打破魔咒的话要先将文件截断成0字节。。。。
snack:想要”a+”的效果变”r+”,在读之前先seek(0),在写之前要truncate一下,确保要写入的位置是文件的末尾。
正确的代码
1
2
3
4
5
|
with open(path, "r+") as f: old = f.read() f.seek(0) f.write(data) f.write(old) |
原理思路:读出原有文件内容,移动索引到开始,写入新的数据,然后写入旧的数据。
以上这篇利用Python在一个文件的头部插入数据的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/junbujianwpl/article/details/73194846