使用例子:
with open('app.txt', 'w', encoding="utf-8") as file:
file.write(ls_cont)
1.用途:是python用来打开本地文件的,他会在使用完毕后,自动关闭文件,无需手动书写close()
2.用法:
with open (file = "你要打开的路径名(或保存内容的地址)",mode = "r/w/a",encoding = "utf-8") as f1:
data = f1.read/write()
print(data)
3.关于mde的三种模式:
r:只读 用read()
w:只写 用write() //会清除之前写的内容
a:追加内容 用write() //会在已经写的内容基础上增加新的内容
open与with open区别
open()完成后必须调用close()方法关闭文件,因为文件对象会占用操作系统的资源,并且操作系统同一时间能打开的文件数量也是有限的,由于文件读写时都有可能产生IOError,一旦出错,后面的f.close()就不会调用。with open()则可以避免这样的情况。
由于文件读写时都有可能产生IOError,一旦出错,后面的f.close()就不会调用。
所以,为了保证无论是否出错都能正确地关闭文件,我们可以使用try … finally来实现:
def readFile():
try:
f =open('C:\\Users\\a\\Desktop\\测试文件 test.txt','r')
try:
data = f.read()
print(data)
except:
print('error occurs while reading file')
finally:
f.close()
except:
print('rror occurs while reading file')
if __name__ == '__main__':
readFile()
这样的操作太麻烦了,可以通过with open语法来代替:
def read_file():
try:
with open('C:\\Users\\a\\Desktop\\测试文件 test.txt','r') as f:
data = f.read()
print(data)
except:
print('error occurs while reading file')
if __name__ == '__main__':
read_file()
执行结果与上例相同。这和前面的try … finally是一样的,但是代码更佳简洁,并且不必调用f.close()方法,文件读写完成后,会自动帮我们调用 close 方法。
-------------------- 分割线 ---------------------
其它扩展阅读:
代码
#文件的读操作
with open('input_filename.txt','r') as f:#r为标识符,表示只读
df=pd.read_csv(f)
print(f.read())
'''
其他标识符:
r: 以只读方式打开文件。
rb: 以二进制格式打开一个文件用于只读。
r+: 打开一个文件用于读写。文件指针将会放在文件的开头。
rb+:以二进制格式打开一个文件用于读写。
'''
#文件的写操作
with open('output_filename.csv', 'w') as f:
f.write('hello world')
'''
其他标识符:
w: 打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
wb: 以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
w+: 打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
wb+:以二进制格式打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
a:打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
ab: 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
a+: 打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
ab+:以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。
''' 4
方法和属性
f.read([size]) #将文件数据作为字符串返回,可选参数size控制读取的字节数
f.readlines([size]) #返回文件中行内容的列表,size参数可选
f.write(str) #将字符串写入文件
f.writelines(strings) #将字符串序列写入文件
f.close() #关闭文件
f.closed #返回布尔值,文件已经被关闭为True,否则为False
f.mode #Access文件打开时使用的访问模式
f.encoding #文件所使用的编码
f.name #文件名
f.newlines #未读取到行分隔符时为None,只有一种行分隔符时为一个字符串,当文件有多种类型的行结束符时,则为一个包含所有当前所遇到的行结束的列表
f.softspace #为0表示在输出一数据后,要加上一个空格符,1表示不加。这个属性一般程序员用不着,由程序内部使用
注意
要读取非UTF-8编码的文本文件,需要给open()函数传入encoding参数
读取时调用read()将一次性读取文件的全部内容,如果文件有10G,内存就爆了,保险起见可反复调用read(size)方法,每次最多读取size个字节的内容。
调用readline()可以每次读取一行内容,调用readlines()一次读取所有内容并按行返回list。
根据需要调用:如果文件很小,read()一次性读取最方便;如果不能确定文件大小,反复调用read(size)比较保险;如果是配置文件,调用readlines()最方便