文件,是计算机中非常重要且常用得东西,平时我们对一个文件的 *** 作通常是打开文件、读取文件 、写文件及关闭文件,在python中也有相应的 *** 作
文件常见的几种读写模式(一般用w+,r+,a+):
w:写入,r:读取,a:追加写入
w+ :如果文件不存在,新建文件,写入时清空写入
r+ :如果文件不存在,则报错,写入时是覆盖写入
a+ :如果文件不存在,则新建文件,写入时追加写入
在python中使用 file.open("文件路径","读写模式")
打开一个文件,在使用open打开文件的时候读写模式默认是读的模式,然后在使用file.read()
读取文件中的内容,如果读取的文件不存在将会报错,encoding='utf-8'
的作用是指定 某种编码格式打开,在不指“utf-8”的时候会报错UnicodeDecodeError: 'gbk' codec can't decode byte 0xa5 in position 14: illegal multibyte sequence
,是因为我在编辑文本的时候使用的是utf-8的编码格式,代码示例:
# 文件的读取
filepath = 'D:/note1.txt' # 文件的路径
file1 = open(filepath, encoding='utf-8') # 打开一个文件 open(参数1,参数2) 参数1:文件路径,参数2.读写模式,默认r
print(file1.read()) # 读取文件中的内容
file1.close() # 关闭文件,使用open方法是,必须要使用close,否则会一直占用内存
打印结果
再read的基础上,我们还可以读取文件按的一行内容,多行内容和整个文件内容常用的方法有file.readline() , file.readlines() , file.read().splitlines()
方法;
file1 = open('D:/note2.txt')
# print(file1.read()) # 读取文件内容,返回值是字符串
# print(file1.readline()) # 读取一行内容
# print(file1.readlines()) # 读取文件内容,返回值是列表,每一行是一个元素 读取内容含有换行符
print(file1.read().splitlines()) # 读取文件内容,返回值是列表,每一行是一个元素,不出现\n
file1.close() # 关闭文件
运行结果
注:以上方法需要单个单独执行
我们发现以上方法,每次有需要使用file.close()
方法进行关闭文件,它的作用就是将文件关闭,同事把内容保存到文件中,如果不使用close *** 作,在file.write()
中的内容就不会被保存到文件中,同时文件就处于打开状态会一直消耗内存,这个时候我们可以使用with open("文件路径") as file
这个语法
# with open() ,用法与open()一样,可以处理多个文件,不需要写close()方法
with open('D:/note2.txt') as f1, open('D:/note1.txt', encoding='utf-8') as f2: # as后边的相当于给文件定义一个变量名
print(f1.read()) # 读取并打印文件f1
print(f2.read()) # 读取并打印文件f2
运行结果:
在写文件的时候,首先要有一个文件,才能进行写入,这个时候要选择写入模式,然后再使用file.write()进行写入文件内容,这个时候再指定的位置就会新建一个文件
# 文件的写入
filepath1 = 'D:/note2.txt'
file1 = open(filepath1, 'w') # w:写入模式
file1.write('学习力\n抗压力\n洞察力\n执行力') # 写入文件内容,\n换行符
file1.close() # 关闭文件
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)