对python for 文件指定行读写操作详解


Posted in Python onDecember 29, 2018

1.os.mknod(“test.txt”) #创建空文件

2.fp = open(“test.txt”,w) #直接打开一个文件,如果文件不存在则创建文件

3.关于open 模式:

详情:

w:以写方式打开,

a:以追加模式打开 (从 EOF 开始, 必要时创建新文件)

r+:以读写模式打开

w+:以读写模式打开 (参见 w )

a+:以读写模式打开 (参见 a )

rb:以二进制读模式打开

wb:以二进制写模式打开 (参见 w )

ab:以二进制追加模式打开 (参见 a )

rb+:以二进制读写模式打开 (参见 r+ )

wb+:以二进制读写模式打开 (参见 w+ )

ab+:以二进制读写模式打开 (参见 a+ )

fp.read([size]) #size为读取的长度,以byte为单位

fp.readline([size]) #读一行,如果定义了size,有可能返回的只是一行的一部分

fp.readlines([size]) #把文件每一行作为一个list的一个成员,并返回这个list。其实它的内部是通过循环调用readline()来实现的。如果提供size参数,size是表示读取内容的总长,也就是说可能只读到文件的一部分。

fp.write(str) #把str写到文件中,write()并不会在str后加上一个换行符

fp.writelines(seq) #把seq的内容全部写到文件中(多行一次性写入)。这个函数也只是忠实地写入,不会在每行后面加上任何东西。

fp.close() #关闭文件。python会在一个文件不用后自动关闭文件,不过这一功能没有保证,最好还是养成自己关闭的习惯。 如果一个文件在关闭后还对其进行操作会产生ValueError

fp.flush() #把缓冲区的内容写入硬盘

fp.fileno() #返回一个长整型的”文件标签“

fp.isatty() #文件是否是一个终端设备文件(unix系统中的)

fp.tell() #返回文件操作标记的当前位置,以文件的开头为原点

fp.next() #返回下一行,并将文件操作标记位移到下一行。把一个file用于for … in file这样的语句时,就是调用next()函数来实现遍历的。

fp.seek(offset[,whence]) #将文件打操作标记移到offset的位置。这个offset一般是相对于文件的开头来计算的,一般为正数。但如果提供了whence参数就不一定了,whence可以为0表示从头开始计算,1表示以当前位置为原点计算。2表示以文件末尾为原点进行计算。需要注意,如果文件以a或a+的模式打开,每次进行写操作时,文件操作标记会自动返回到文件末尾。

fp.truncate([size]) #把文件裁成规定的大小,默认的是裁到当前文件操作标记的位置。如果size比文件的大小还要大,依据系统的不同可能是不改变文件,也可能是用0把文件补到相应的大小,也可能是以一些随机的内容加上去。

#coding: utf-8

#打开文件open(),默认只读"r".
#exp1:相对路径
f = open(".\\test001.txt") 
data = f.read()
print(data)

#exp2:绝对路径
f = open("test001.txt","r")
data = f.read()
print(data)

#exp3:绝对路径
f = open("D:\\mytest\\test001.txt")
data = f.read()
print(data)


#打开并关闭文件:
f = open("test001.txt","r")
data = f.read()
print(data)
f.close()


#写文件write()不换行:
f = open("test001.txt","w")
f.write("ddddddddddddd"+"\n")
f.close()

第一种方式读写指定行:

#写文件writelines()换行:
with open("test001.txt","w") as z:
 z.write("33333333"+"\n")
 z.write("cccccccccc"+"\n")



#读取指定行:
with open("test001.txt",'r') as x:
 line = x.readlines()
 first_line = line[0]
 second_line = line[1]
 print(first_line)
 print(second_line)

第二种方式读写指定行:

#coding: utf-8


#将文件读进列表(反复追加)中:
lines = []
with open("test001.txt","r") as y:
 for line in y:
  lines.append(line)
 y.close()

#在列表中插入文本数据:
lines.insert(0, "aaaa\n")
lines.insert(1, "bbbb\n")
print(lines)

#利用分隔符连接:
s = ''.join(lines)
print(s)

#写到文件中去:
with open("test001.txt","w") as z:
 z.write(s)
 z.close()

#再次读取文件中的数据:
with open("test001.txt","r") as x:
 data = x.read()
 print(data)
 x.close()
#清空列表:
del lines[:]
print(lines)

第三种方式读写指定行:

#coding: utf-8


#在列表中插入文本数据:
lines = []
a = "abc123"
b = "edf456"
lines.insert(0, a)
lines.insert(1, b)
print(lines)

#利用分隔符连接:
s = '\n'.join(lines)

#写到文件中去:
with open("test001.txt","w") as z:
 z.write(s)
 z.close()

#再次读取文件中的数据:
with open("test001.txt","r") as x:
 data = x.read()
 print(data)
 x.close()

#清空列表:
# del lines[:]
# print(lines)

第三种的小改方式:

#在列表中插入文本数据:
lines = []
lines.insert(0, "aaaa\n")
lines.insert(1, "bbbb\n")
print(lines)

#利用分隔符连接:
s = ''.join(lines)

#写到文件中去:
with open("test001.txt","w") as z:
 z.write(s)
 z.close()

#再次读取文件中的数据:
with open("test001.txt","r") as x:
 data = x.read()
 print(data)
 x.close()

#清空列表:
# del lines[:]
# print(lines)

备注:第一种方式,比较生硬,不推荐。第二种方式可以反复追加内容,第三种方式只追加一次,不会重复。

以上这篇对python for 文件指定行读写操作详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
SublimeText 2编译python出错的解决方法(The system cannot find the file specified)
Nov 27 Python
Python使用smtplib模块发送电子邮件的流程详解
Jun 27 Python
python命令行解析之parse_known_args()函数和parse_args()使用区别介绍
Jan 24 Python
Django中Forms的使用代码解析
Feb 10 Python
运用TensorFlow进行简单实现线性回归、梯度下降示例
Mar 05 Python
解决tensorflow1.x版本加载saver.restore目录报错的问题
Jul 26 Python
使用TensorFlow实现简单线性回归模型
Jul 19 Python
python针对mysql数据库的连接、查询、更新、删除操作示例
Sep 11 Python
python 内置函数汇总详解
Sep 16 Python
使用apiDoc实现python接口文档编写
Nov 19 Python
Pytorch maxpool的ceil_mode用法
Feb 18 Python
python interpolate插值实例
Jul 06 Python
Python实现二维曲线拟合的方法
Dec 29 #Python
python修改txt文件中的某一项方法
Dec 29 #Python
神经网络相关之基础概念的讲解
Dec 29 #Python
Python实现的KMeans聚类算法实例分析
Dec 29 #Python
Python使用pyshp库读取shapefile信息的方法
Dec 29 #Python
Python实现的线性回归算法示例【附csv文件下载】
Dec 29 #Python
Python 确定多项式拟合/回归的阶数实例
Dec 29 #Python
You might like
DC《小丑》11项提名领跑奥斯卡 Netflix成第92届奥斯卡提名最大赢家
2020/04/09 欧美动漫
php知道与问问的采集插件代码
2010/10/12 PHP
PHP的加密方式及原理
2012/06/14 PHP
php超快高效率统计大文件行数
2015/07/05 PHP
PHP实现的AES 128位加密算法示例
2019/09/16 PHP
jquery拖动插件(jquery.drag)使用介绍
2013/06/18 Javascript
选择器中含有空格在使用示例及注意事项
2013/07/31 Javascript
IE中的File域无法清空使用jQuery重设File域
2014/04/24 Javascript
JS获取单击按钮单元格所在行的信息
2014/06/17 Javascript
详解JavaScript中Hash Map映射结构的实现
2016/05/21 Javascript
canvas快速绘制圆形、三角形、矩形、多边形方法介绍
2016/12/29 Javascript
JavaScript原生节点操作小结
2017/01/17 Javascript
AngularJS读取JSON及XML文件的方法示例
2017/05/25 Javascript
Angular动画实现的2种方式以及添加购物车动画实例代码
2018/08/09 Javascript
Vue.js单向绑定和双向绑定实例分析
2018/08/14 Javascript
vue初始化动画加载的实例
2018/09/01 Javascript
vue项目中锚点定位替代方式
2019/11/13 Javascript
es6中Promise 对象基本功能与用法实例分析
2020/02/23 Javascript
vue滑动吸顶及锚点定位的示例代码
2020/05/10 Javascript
JavaScript冒泡算法原理与实现方法深入理解
2020/06/04 Javascript
vue 解决data中定义图片相对路径页面不显示的问题
2020/08/13 Javascript
vue在图片上传的时候压缩图片
2020/11/18 Vue.js
js加减乘除精确运算方法实例代码
2021/01/17 Javascript
Python进行数据提取的方法总结
2016/08/22 Python
Python实现简单的语音识别系统
2017/12/13 Python
tensorflow 用矩阵运算替换for循环 用tf.tile而不写for的方法
2018/07/27 Python
Python多进程原理与用法分析
2018/08/21 Python
idea创建springMVC框架和配置小文件的教程图解
2018/09/18 Python
python版飞机大战代码分享
2018/11/20 Python
Python对Excel按列值筛选并拆分表格到多个文件的代码
2019/11/05 Python
Python3爬虫中Selenium的用法详解
2020/07/10 Python
公司离职证明范本(5篇)
2014/09/17 职场文书
销售经理岗位职责范本
2015/04/02 职场文书
七个Python必备的GUI库
2021/04/27 Python
Java 获取Word中所有的插入和删除修订的方法
2022/04/06 Java/Android
3050和2060哪个好 性能差多少 差距有多大 谁更有性价比
2022/06/17 数码科技