利用Python在一个文件的头部插入数据的实例
2018-05-02 09:20
621 查看
在一个文件的末尾追加数据是很常用的。在使用过程中应该都比较熟悉不会出现什么错误。但是往一个文件头部插入数据可能或多或少会碰到一些问题。
看似正确的错误代码
很多代码看似正确,但是其实都是错的。一起来看下这些代码
1、看似正确的错误代码1
with open(path, "r+") as f: f.seek(0) f.write(data)
确实是从头写了,而且有些原有数据确实在,但是数据有问题。。。。
因为”r+”方式写文件操作没有插入的语义,只有写文件的含义,原来位置如果有数据,不会后移的,是覆盖掉了。。。。所以,你可能会看到一些老的数据。不仔细辨别可能就天真地以为成功了。。。
2、看似正确的错误代码2
with open(path, "w+") as f: old = f.read() f.seek(0) f.write(data) f.write(old)
你读取到的数据永远为空。。。。
因为”w+”的含义就是截取长度为0然后写入文件。
3、看似正确的错误代码3
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一下,确保要写入的位置是文件的末尾。
正确的代码
with open(path, "r+") as f: old = f.read() f.seek(0) f.write(data) f.write(old)
原理思路:读出原有文件内容,移动索引到开始,写入新的数据,然后写入旧的数据。
以上这篇利用Python在一个文件的头部插入数据的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- 利用Python在一个文件的头部插入数据
- Python利用pandas计算多个CSV文件数据值的实例
- Problem Description 有n(n<=100)个整数,已经按照从小到大顺序排列好,现在另外给一个整数x,请将该数插入到序列中,并使新的序列仍然有序。 Input 输入数据包含多个测试实例,每组数据由两行组成,第一行是n和m,第二行是已经有序的n个数的数列。n和m同时为0标示输入数
- php 在文件指定行插入数据实例
- 从数据库中调用数据生成rar文件(自己的一个小实例)
- 002_009 Python 从Zip中读取数据 直接检查一个zip格式的归档文件部分或所有文件而且不用解压
- sql Server 批量插入以及sql Server数据导入到mysql sqlServer数据每10000条导出一个文件
- 《windows核心编程》学习笔记——在同一个可执行文件或dll的多个实例间共享静态数据
- python实现的一个p2p文件传输实例
- 从Apache的日志文件收集和提供统计数据(一个Python插件架构的简单实现)
- python for android : 一个简单文件浏览器的实例 play mp3
- 利用Python进行数据分析--数据加载、存储与文件格式
- python实现的一个p2p文件传输实例
- sqlserver 利用数据库脚本实现取一个表中的数据插入到另一个表
- 一个利用创建临时表后插入数据的查询
- 利用存储过程把两个表的数据插入到一个新表中(存储过程中写两个游标)
- .若A,B两个实体是一对多的包含关系。利用存储过程,实现数据访问层层的一个实例。
- Python操作sqlite3快速、安全插入数据(防注入)的实例
- 利用Access来插入Postgres批量数据的一个方法
- Python操作sqlite3快速、安全插入数据(防注入)的实例