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把文件补到相应的大小,也可能是以一些随机的内容加上去。
THE END
分享
二维码
< <上一篇
下一篇>>