首页 > 代码库 > Python内置函数之open()
Python内置函数之open()
open(file, mode=‘r‘, buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)
打开一个文件,返回一个对应的文件对象。
file参数 文件的路径,相对路径、绝对路径都行。
mode参数 以何种模式打开文件
‘r‘: 以只读模式打开(缺省模式)(必须保证文件存在)
‘w‘:以只写模式打开。若文件存在,则会自动清空文件,然后重新创建;若文件不存在,则新建文件。使用这个模式必须要保证文件所在目录存在,文件可以不存在。该模式下不能使用read*()方法
‘a‘:以追加模式打开。若文件存在,则会追加到文件的末尾;若文件不存在,则新建文件。该模式不能使用read*()方法。
下面四个模式要和上面的模式组合使用
‘b‘:以二进制模式打开
‘t‘: 以文本模式打开(缺省模式)
‘+‘:以读写模式打开
‘U‘:以通用换行符模式打开
常见的mode组合
‘r‘或‘rt‘: 默认模式,文本读模式
‘w‘或‘wt‘: 以文本写模式打开(打开前文件会被清空)
‘rb‘: 以二进制读模式打开
‘ab‘: 以二进制追加模式打开
‘wb‘: 以二进制写模式打开(打开前文件会被清空)
‘r+‘: 以文本读写模式打开,可以写到文件任何位置;默认写的指针开始指在文件开头, 因此会覆写文件
‘w+‘: 以文本读写模式打开(打开前文件会被清空)。可以使用read*()
‘a+‘: 以文本读写模式打开(写只能写在文件末尾)。可以使用read*()
‘rb+‘: 以二进制读写模式打开
‘wb+‘: 以二进制读写模式打开(打开前文件会被清空)
‘ab+‘: 以二进制读写模式打开
buffering参数 表示文件在读取时使用的缓冲策略
0: 代表buffer关闭(只适用于二进制模式)
1: 代表line buffer(只适用于文本模式)
>1: 表示初始化的buffer大小
encoding参数 打开文件时采用的编码格式(需要和保存时的一致,不然会乱码)
errors参数 定义报错级别
‘strict‘ 严格级别,字符编码有报错即抛出异常,也是默认的级别,errors参数值传入None按此级别处理.
‘ignore‘ 忽略级别,字符编码有错,忽略掉.
‘replace‘ 替换级别,字符编码有错的,替换成?.
newline参数 表示用于区分的换行符(只对文本模式有效,可以取的值有None,‘\n‘,‘\r‘,‘‘,‘\r\n‘)
closefd参数 表示传入的file参数类型(默认为True),传入文件路径时一定为True,传入文件句柄(文件句柄就是一个内存地址,
打开文件时给文件附加的一串数字)则为False。
Python内置函数之open()