一、文件的打开与关闭
在python中,使用open函数,打开一个已经存在的文件,或者新建一个新文件。
函数语法 open(name[, mode[, buffering[,encoding]]])
name : 一个包含了你要访问的文件名称的字符串值(区分绝对路径和相对路径)。
mode : mode 决定了打开文件的模式:只读,写入,追加等。所有可取值见如下的完全列表。这个参数是非强制的,默认文件访问模式为只读(r)。
buffering : 如果 buffering 的值被设为 0,就不会有寄存。如果 buffering 的值取 1,访问文件时会寄存行。 如果将 buffering 的值设为大于 1 的整数,表明了这就是的寄存区的缓冲大小。如果取负值,寄存区的缓冲大小则为系统默认。
简单来说就是:
open('文件名','打开的模式',encoding='编码方式')
f=open('python.txt','r',encoding='utf-8')
对于文件的操作结束之后,使用close()来关闭文件:
f=open('python.txt','r',encoding='utf-8')
f.close()
二、文件的读写模式
对文件的操作有几种模式,常用的如下:
①r:只读的方式打开,若文件不存在报错
②w:只写的方式打开,若文件存在则覆盖,不存在则创建
③a:打开一个文件进行追加内容,若存在则打开,不存在则创建
④r+:读写,会将文件指针调到文件的头部
⑤w+:读写,文件存在覆盖源文件,不存在则创建
⑥a+:追加读写,会将文件的指针调到文件末尾
具体的见下表:
访问模式 | 说明 |
r | 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。 |
w | 打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。 |
a | 打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
rb | 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式 |
wb | 以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。 |
r | 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。 |
w | 打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。 |
a | 打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
rb | 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式 |
wb | 以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。 |
read(num):可以读取文件里面的内容。num表示要从文件中读取的数据的长度(单位是字节),如果没有传入num,那么就表示读取文件中所有的数据:
# #打开文件
f = open('python.txt','r',encoding='utf-8') #以utf-8方式打开文件
#读取文件内容
word=f.read(10) #读取10个字符
#输出读取内容
print(word)
#关闭文件
f.close()
还可以使用关键字with进行操作,语法为:
with open() as f:
eg:
with open('python.txt','r+',encoding='utf-8') as f:
word = f.read()
print(word)
关键字with在不再需要访问文件后将其关闭。这可让Python去确定:你只管打开文件,并在需要时使用它,Python自会在合适的时候自动将其关闭。 也可以调用open()和close()来打开和关闭文件,但这样做时,如果程序存 在bug,导致close()语句未执行,文件将不会关闭。
三、文件的读写
按行读取:readlines():可以按照行的方式把整个文件中的内容进行一次性读取,并且返回的是一个列表,其中每一行的数据为一个元素。
#1
f = open('python.txt','r',encoding='utf-8') #以utf-8方式打开文件
#读取文件内容
word=f.readlines()
#输出读取内容
print(word)
#关闭文件
f.close()
#2
with open('python.txt','r+',encoding='utf-8') as f:
word = f.readlines()
print(word)
写入文件:
如果你要写入的文件不存在,函数open()将自动创建它。
我们使用文件对象的方法write()将一个字符串写入文件。
这个程序是没有终端输出 函数write()不会在你写入的文本末尾添加换行符,需要手动添加。
'''
写入文件:write
'''
#覆盖源文件:hello,world!
f = open('python.txt','w',encoding='utf-8')
word = '十年生死两茫茫,不思量,自难忘,千里孤坟,无处话凄凉。'
f.write(word)
f.close()
#追加内容
f = open('python.txt','a',encoding='utf-8')
word = '\n十年生死两茫茫,不思量,自难忘,千里孤坟,无处话凄凉。'
f.write(word)
f.close()
常用的函数如下:
函数名 | 说明 |
read(size) | size为读取的长度,打开模式有b(二进制) 就按byte为单位,无b就以字符为单位 |
readline()/readlines() | 读取第一行/把文件每一行作为一个list的一个成员,并返回这个list。 |
write() | 把str写到文件中,write()并不会在str后加上一个换行符 |
writelines(seq) | 把seq的内容全部写到文件中(多行一次性写入)。这个函数也只是忠实地写入,不会在每行后面加上任何东西。 |
close() | 关闭文件 |
函数名 | 说明 |
flush() | 把缓冲区的内容写入硬盘 |
tell() | 返回文件游标操作的当前位置,以文件的开头为原点 |
write() | 把str写到文件中,write()并不会在str后加上一个换行符 |
seek(offset[,whence]) | offset -- 开始的偏移量,也就是代表需要移动偏移的字节数 whence:可选,默认值为 0。给offset参数一个定义,表示要从哪个位置开始偏移;0代表从文件开头开始算起,1代表从当前位置开始算起,2代表从文件末尾算起。 |
truncate() | 把文件裁成规定的大小,默认的是裁到当前文件操作标记的位置。如果size比文件的大小还要大,依据系统的不同可能是不改变文件,也可能是用0把文件补到相应的大小,也可能是以一些随机的内容加上去。 |