Python文件操作
内容纲要
一 文件的操作
1.文件的打开和关闭
文件操作的流程
open函数
- 在python中,使用open函数,打开一个已经存在的文件,或者新建一个新文件。
- 函数语法 open(name[, mode[, buffering[,encoding]]])
- name : 一个包含了你要访问的文件名称的字符串值(区分绝对路径和相对路径)。
- mode : mode 决定了打开文件的模式:只读(r),写入(w),追加(a)等。所有可取值见如下的完全列表。这个参数是非强制的,默认文件访问模式为只读(r)。
- buffering : 如果 buffering 的值被设为 0,就不会有寄存。如果 buffering 的值取 1,访问文件时会寄存行。如果将 buffering 的值设为大于 1 的整数,表明了这就是的寄存区的缓冲大小。如果取负值,寄存区的缓冲大小则为系统默认。
2.文件的关闭
- 对于文件的操作结束之后,使用close()来关闭文件
#语法
#文件对象.close()
#实列
file1=open('Test.txt','w')
file1.close()
open ('文件名','打开的模式')
r:只读的方式打开,如果文件不存在会提示错误
w:只写的方式打开,如果文件存在则覆盖,不存在则创建
a:打开一个文件进行追加内容,如果存在则打开,不存在则创建新的文件
r+:读写,会将文件指针调到文件的头部
w+:读写,文件不存在直接创建,存在覆盖源文件
a+:追加读写,会将文件的指针调到文件的末尾
二 文件的读写
1.文件的读
- read(num):可以读取文件里面的内容。num表示要从文件中读取的数据的长度(单位是字节),如果没有传入num,那么就表示读取文件中所有的数据
'''
文件的读写
read(num):读取文件内容,num表示指定的长度,如果没有则读取所有的数据
'''
#打开文件
files = open('python.txt','r',encoding= 'utf-8' )
print(files)
# 读取文件内容
content = files.read() #读取数据保存在content变量当中
content = files.read(10) #传入参数会读取指定的长度
# 输出读取的内容
print(content)
# 关闭文件
files.close()
2.with…open
- 关键字with在不再需要访问文件后将其关闭。这可让Python去确定:你只管打开文件,并在需要时使用它,Python自会在合适的时候自动将其关闭。
- 也可以调用open()和close()来打开和关闭文件,但这样做时,如果程序存在bug,导致close()语句未执行,文件将不会关闭。
'''
with open as filename:
with...open和open的区别:关键字with不在需要访问文件后将其关闭,python会自动判断什么时候去关闭
'''
with open('python.txt','r',encoding= 'utf-8' ) as files:
contnet = files.read()
print(contnet)
3. readlines
- readlines:可以按照行的方式把整个文件中的内容进行一次性读取,并且返回的是一个列表,其中每一行的数据为一个元素
'''
readlines
可以安装行的方式吧整个文件中的内容进行一次性读取,
并且返回一个列表,其中每一行的数据为一个元素
'''
#打开文件
files = open('python.txt','r',encoding= 'utf-8' )
print(files)
# 读取文件内容
content = files.readlines()
#
# 输出读取的内容
print(content)
# 关闭文件
files.close()
'''
使用with...open
'''
with open('python.txt','r',encoding= 'utf-8' ) as files:
contnet = files.readlines() #按行读取文件内容,保存在列表当中
print(contnet)
'''
逐行读取
'''
#用open结合for循环逐行读取
files = open('python.txt','r',encoding= 'utf-8')
i = 1
for line in files:
#没有使用read
print('这是第%d行内容:%s'%(i,line))
i+=1
files.close()
'''
用with结合for
'''
with open('python.txt','r',encoding= 'utf-8') as files:
i = 1
for line in files:
#没有使用read
print('这是第%d行内容:%s'%(i,line))
i+=1
'''
用open结合for,readlines循环逐行读取
'''
files = open('python.txt','r',encoding= 'utf-8')
contents = files.readlines()#逐行读取内容
files.close()#关闭文件
i = 1
for line in contents:
#没有使用read
print('这是第%d行内容:%s'%(i,line))
i+=1
files.close()
2.文件的写
- 如果你要写入的文件不存在,函数open()将自动创建它。
- 我们使用文件对象的方法write()将一个字符串写入文件.这个程序是没有终端输出
- 函数write()不会在你写入的文本末尾添加换行符,需要手动添加\n
'''
写入文件
write
'''
#以写的方式打开一个文件
files = open('python.txt','w',encoding='utf-8') #覆盖源文件
files = open('python.txt','a',encoding='utf-8') #在源文件的基础上最佳
content = 'hello,爱你哟'
content = '元旦一起喝咖啡,看电影可以吗?'
files.write(content) #写入数据
files.close()
#
with open('python.txt','a',encoding='utf-8') as files:
content = '想和你一起去开海'
files.write(content)
常用函数
函数名 | 说明 |
---|---|
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把文件补到相应的大小,也可能是以一些随机的内容加上去。 |
共有 0 条评论