python基础之文件处理知识总结
发布时间:2021-06-22 15:26:45
一、open()方法
python open()方法用于打开一个文件,并返回文件对象,在对文件处理的过程中都需要用到这个函数,如果文件无法打开,会抛出OSError。
注意:使用open()方法的时候一定到保证关闭文件对象,文件里面的内容才会被保存,关闭文件需要调用close()方法。
open()方法常用的形式是接收两个参数:文件名(file)和模式(mode)
基本语法:
open(file,mode='r')
完整的语法:
open(file,mode='r',buffering=1,encoding=None,errors=None,newline=None,closefd=True)
参数说明:
mode表示文件打开模式,有几种模式呢?参考如下:
r: 以只读的方式打开文件。文件的指针将会放到文件的开头。这是文件默认的打开模式
w: 打开一个文件只能用于写入。如果文件存在则打开文件,并且从头开始编辑,文件原有的内容会被清空。如果文件不存在,则会创建新的文件
a: 打开一个文件用于在里面追加内容。如果文件已经存在,文件指针将会放在文件的结尾。也就是新的内容会被写道已有的内容之后。如果该文件不存在的话,创建新文件进行写入
r+:打开一个文件用于读写,文件指针将会放在文件的开头
a+: 打开一个文件用于读写,如果文件已经存在,文件指针将会放在文件的结尾,文件打开时回事追加模式,如果该文件不存在,创建新的文件用于读写
w+: 打开一个文件用于读写。如果该文件已经存在,则打开已经存在文件,并且从头开始编辑,即原有的内容会被删除。如果该文件不存在,则创建新文件
b: 二进制文件
rb:以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认的模式,一般用于非文本文件,如图片,视频等
wb: 以二进制格式打开一个文件只用于写入。如果该文件已经存在则打开文件,并从文件的开头开始编辑,即原有的内容会被删除,如果该文件不存在,创建新文件。一般用于非文本文件,如图片,视频等
ab:以二进制格式打开一个文件用于追加,如果该文件已经存在,文件指针将会放在文件的结尾,也就是说,新的内容将会被写道已有的内容之后,如果该文件不存在,则创建新的文件并写入
ab+:以二进制格式打开一个文件用于追加,如果该文件已经存在,文件指针将会放在文件的结尾,如果该文件不存在,创建新的文件用于读写
例1:以w模式打开文件
1 2 3 4 5 6 7 8 9 | f = open ( 'myfile.txt' , 'w' )
f.write( 'hello,world!' )
f.close()
在当前路径下成一个myfile.txt文件,并且把 'hello world' 写到该文件
myfile.txt内容如下:
hello,world!
|
例2: 以a模式打开文件
1 2 3 4 5 6 7 8 9 10 | f = open ( 'myfile.txt' , 'a' )
f.write( '\ngood lucky' )
f.close()
会在文件末尾追加内容,不会覆盖原来的内容
myfile.txt内容如下:
hello,world!
good,lucky!
|
例3: 再以w模式打开文件,会把原来内容覆盖掉
1 2 3 4 5 6 7 8 | f = open ( 'myfile.txt' , 'w' )
f.write( 'welcome!' )
f.close()
myfile.txt内容如下:
welcome!
|
例4: 以r的模式读文件
1 2 3 4 5 6 7 | f = open ( 'myfile.txt' , 'r' )
f.write( '\nhello!' )
f.close()
f.write( '\nhello!' )
io.UnsupportedOperation: not writable
|
例5: 以r+的模式读文件
1 2 3 4 5 6 7 8 9 10 | f = open ( 'myfile.txt' , 'r+' )
f.write( '\nhello!' )
f.close()
r + :打开一个文件用于读写,文件指针将会放在文件的开头
myfile.txt内容:
1 - - - - - - - - - - - - - - > 此处表示空行
2hello !
|
例6: 以w+模式写文件
1 2 3 4 5 6 7 8 9 | f = open ( 'myfile.txt' , 'w+' )
f.write( 'love!' )
f.close()
如果该文件已经存在,则打开已经存在文件,并且从头开始编辑,即原有的内容会被删除。如果该文件不存在,则创建新文件。
myfile.txt内容:
love!
|
二、read()方法
读取文件中的所有内容,读取之后光标移动到文件末尾。 必须以r或r+模式,才可以使用read()。
例7: 以w+模式写文件,再以r+模式来读取文件内容
1 2 3 4 5 6 7 8 9 10 | f = open ( 'myfile.txt' , 'w+' )
f.write( 'hello,world!\ngood,lucky!!' )
f.close()
w + 如果该文件已经存在,则打开已经存在文件,并且从头开始编辑,即原有的内容会被删除。如果该文件不存在,则创建新文件。
myfile.txt内容:
hello,world!
good,lucky!!
|
1 2 3 4 5 6 | f = open ( 'myfile.txt' , 'r+' )
print (f.read())
hello,world!
good,lucky!!
|
例8:以r+模式写文件,再来读取文件
1 2 3 4 5 6 7 8 9 10 11 12 | f = open ( 'myfile.txt' , 'r+' )
f.write( '\nwelcom' )
print (f.read())
rld!
good,lucky!!
1 - - - - - - - - - - - >空行
2welcomrld !
3good ,lucky!!
|
三、readlines()方法
readlines()一行行读文件
例9:
1 2 3 4 5 6 7 8 9 10 11 | f = open ( 'myfile.txt' , 'r+' )
print (f.readline())
print (f.readline())
print (f.readline())
welcomrld!
good,lucky!!
|
readlines()
一行行读取文件内容,然后存放在列表中,可以读取所有行的内容,每行的内容都作为列表中的一个元素存在列表里,并且返回一个列表。 这个列表可以使用for..in 结构进行处理。 如果碰到EOF结束符,则返回空字符。
例10:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | f = open ( 'myfile.txt' , 'r' )
print (f.readlines())
[ '\n' , 'welcomrld!\n' , 'good,lucky!!' ]
f = open ( 'myfile.txt' , 'r' )
for i in f.readlines():
i = i.strip()
print (i)
- - - - - - - - - - - >空行
welcomrld!
good,lucky!!
|
四、seek()方法
seek() 用于移动文件读取指针到指定位置
1 2 3 4 5 | 语法如下:f.seek(offset,[,whence])
offset - - 开始的偏移量,也就是代表需要移动偏移的字节数,如果是负数,表示从倒数第几位开始
whence - - 可选参数,默认是 0 。给offset定义一个参数,表示从哪个位置开始偏移; 0 代表从文件开头算起; 1 代表从当前位置开始算起; 2 代表从文件末尾算起。
如果操作成功,则返回新的文件位置;如果操作失败,返回 - 1
|
例11:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | f = open ( 'workfile.txt' , 'wb+' )
print (f.write(b '0123456789abcde' ))
f.seek( 5 )
print (f.read( 1 ))
f.seek( - 3 , 2 )
print (f.read( 1 ))
15
b '5'
b 'c'
workfile.txt内容如下:
0123456789abcde
|
例12:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | f = open ( 'myfile.txt' , 'r' )
print ( 'filename is :' ,f.name)
line = f.readline().strip()
print ( '第一次读取的数据是%s' % (line))
f.seek( 0 , 0 )
line = f.readline().strip()
print ( '第二次读取的数据是%s' % (line))
filename is : myfile.txt
第一次读取的数据是good,lucky!!
第二次读取的数据是good,lucky!!
myfile.txt内容如下:
good,lucky!!
|
1 2 3 4 5 6 7 8 9 10 11 12 | f = open ( 'myfile.txt' , 'r' )
print ( 'filename is :' ,f.name)
line = f.readline().strip()
print ( '第一次读取的数据是%s' % (line))
line = f.readline().strip()
print ( '第二次读取的数据是%s' % (line))
filename is : myfile.txt
第一次读取的数据是good,lucky!!
第二次读取的数据是
|
五、tell()函数
返回文件的当前位置
参考: https://www.runoob.com/python/file-tell.html
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | f = open ( 'myfile.txt' , 'r+' )
print ( 'filename is :' , f.name)
line = f.readline()
print ( '读取的数据是%s' % (line))
line1 = f.readline()
print ( '读取的数据是%s' % (line1))
pos = f.tell()
print ( 'current position is %d:' % (pos) )
f.close()
filename is : myfile.txt
读取的数据是good,lucky!!
读取的数据是
current position is 12 :
myfile.txt内容如下:
good,lucky!!
filename is : myfile.txt
读取的数据是good,lucky!!
读取的数据是g
current position is 15 :
myfile.txt内容如下:
good,lucky!!
g
|
到此这篇关于python基础之文件处理知识总结的文章就介绍到这了