python连续写⼊⽂件操作_你真的会⽤python进⾏⽂件操作吗本篇⽂章主要⽐较系统的介绍了python中⽂件操作,以及在在使⽤中需要注意的问题。
什么是⽂件
⽂件是系统存储区域的⼀个命名位置,⽤来存储⼀些信息,便于后续访问。能够在⾮易失性存储器中实现持续性存储,⽐如在硬盘上。当我们要读取或者写⼊⽂件时,我们需要打开⽂件;在操作完毕时,我们需要关闭⽂件,以便释放和⽂件操作相关的系统资源,因此,⽂件操作的主要包括以下:打开⽂件
读取或者写⼊
关闭⽂件
打开⽂件
Python使⽤内置的open()函数打开⼀个⽂件,并且返回⼀个⽂件对象,也叫句柄(handle)。
f = open("") # 在本⽂件夹下⾯的⼀个⽂件
f = open("C:/") # 全路径
再打开⽂件时,我们需要指定⽂件打开的模式,当我们需要读取⽂件时,使⽤f = open("", 'r'),写⼊⽂件时,使⽤f =
open("", 'w'),追加输⼊时f = open("", 'a'),这⾥的a就是append的意思。追加模式和写⼊模式的区别就是,写⼊模式打开⼀个⽂件时,⽆论这个⽂件是否有内容,都会被清空再写⼊;在使⽤追加模式时,打开的⽂件,只是在原有的内容上继续进⾏写⼊。同时我们也要制定以⽂本模式打开还是⼆进制模式打开。⽂本模式(text mode)和⼆进制(binary mode)模式的区别
⽂本模式中,读取时操作系统的换⾏符('\n' on Unix,'\r\n' on Windows)会被转换成Python的默认换⾏符\n,写⼊时会将默认的换⾏符转换为操作系统的换⾏符;在⼆进制模式中不会转换。这个转化在对⽂本⽂件没有影响,但是对于⼆进制数据会有影响,⽐如图像⽂件或者EXE⽂件等。因此,再打开这类⽂件时,⼀般使⽤⼆进制模式进⾏读写
常⽤模式
| r | ⽂本模式,读取 |
| rb | ⼆进制模式,读取 |
| w | ⽂本模式,写⼊ |
| wb | ⼆进制模式,写⼊ |
| a | ⽂本模式,追加 |
| ab | ⼆进制模式,追加 |
| + | 可读可写 |
f = open("", 'r') # 读模式
f = open("", 'w') # 写模式
f = open("img.bmp",'r+') # 可读可写
f = open("img.bmp",'w+') # 可读可写
f = open("img.bmp",'rb') # ⼆进制读取
如何关闭⽂件
当⽂件操作结束时,我们最好主动关闭⽂件。尽管Python有垃圾回收(garbage collector)机制,去清理不⽤的对象,但是最好还是⾃⼰关闭⽂件。
最简单的⽅法就是:
f = open("app.log", 'r')
do_something()
f.close()
但是这个办法不安全,因为在进⾏其他操作时,可能会出现异常,程序退出,那么关闭⽂件的语句就不会被执⾏。
因此,可以⽤语句来处理:
try:
f = open('app.log', 'r')
do_something()
finally:
f.close()
⽆论是否发⽣异常,关闭⽂件的指令都会被执⾏。
但是python官⽅给出的最佳⽤法是:
with open('app.log', 'r') as f:
do_something()
使⽤这种⽤法,我们不必调⽤close()⽅法,在with语句程序内部就会执⾏,⽆论内部是否出现异常。with语句被称为上下⽂管理器,我们可以暂且不管这个的原理,只需要知道使⽤with语句,关闭⽂件的操作会被⾃动执⾏,这也是官⽅推荐的最佳⽤法,⽐⽤语句写起来简单。
⽂件操作
写⼊⽂件
主要介绍两个⽅法:
1.write()⽅法
这个⽅法的参数是⼀个单独的字符串,⽐如:
lines = ['line1', 'line2']
with open('', 'w') as f:
s = ''
for data in lines:
s += data
s += '\n'
f.write(s)
其实更好的写法是使⽤join函数:
lines = ['line1', 'line2']
with open('', 'w') as f:
f.write('\n'.join(lines))
2.writelines()⽅法
参数是⼀组可迭代的字符串,⽐如
lines = ['line1', 'line2']
with open('', 'w') as f:
new_lines = []
for data in lines:
new_lines.append(data+'\n')
f.writelines(new_lines)
其实更加优雅的写法,可以使⽤⽣成器:
lines = ['line1', 'line2']
with open('', 'w') as f:
f.writelines("%s\n" % l for l in lines)
读取⽂件
这⾥介绍四种⽤法,后⾯都默认⽂件已经被打开了:
result = f.read()
这⾥返回的是⽂件内容,是str类型的结果,这个⽅法还带⼀个数值类型的参数,指定读取多少内容,如果省略了或者是负数,那么就返回⽂件的全部内容。
result = f.readline()
返回的也是字符串,不过是⼀⾏内容,继续调⽤,就会返回下⼀⾏内容
result = f.readlines()
这⾥返回的是⼀个列表,但是当数据较⼤时,这样的⽤法会很占⽤内存,不推荐在数据量⼤时使⽤
4.直接循环⽂件对象
for line in f:
print line
do_something()
这样的⽤法节省内存,快速,并且代码还简单
result = f.readlines()
writelines()方法将什么写入文件------------------------
result = list(f)
这两种写法返回的结果是⼀样的
显然我们推荐第四种⽤法。
如何处理⼤⽂件
⼤⽂件主要问题在于占⽤内存较⼤,我们不能⼀下⼦将⽂件全部内容读⼊内存,最好的做法如下:
with open("") as f:
for line in f:
do_something_with(line)
⼀⾏⼀⾏读取,内存不会爆,同时速度也更快,使⽤with语句,⽆论内部是否出现异常,在结束时,⽂件对象都会被关闭,因此在处理⼤⽂件时,最好这样来做。
如果你喜欢这篇⽂章,请点个赞吧,也可以私信或者在评论区留⾔进⾏交流

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。