目录
前言:
打开文件最常用的三种方法:
方法一:open() 方法
✨✨其中对参数解释
✨✨对mode参数解释:
✨✨对编码方式的解释:
✨✨对file对象解释:
方法二:with open( ) as ……
✨✨方法二介绍:
方法三: try ... finally
✨✨方法三介绍:
结语:
本篇博客主要向各位小伙伴们介绍的Python中✨✨
✨✨,带各位掌握Python基础,希望各位小伙伴们能够在这里收获到更多知识!让我们一起学习!一起进步 作者希望:由于博主水平限制,博客难免会有错误和不准之处,我也非常希望各位小伙伴能够在留言区指出。让我们一起共勉。
最后如果觉得博主文章还不错的话,请三连支持一下哦
1、open() 函数常用形式是接收两个参数:文件名(file)和模式(mode)
open(file , mode = ' w')
注意:使用 open() 方法一定要保证关闭文件对象,即调用 close() 方法,目的是不让其占用内存空间节省内存
2、open()函数的完整语法格式如下:
open(file, mode = 'r', buffering = None, encoding = None, errors = None, newline = None, closefd = True,openrwi= None)
- file: 必需,文件路径(相对或者绝对路径)。
- mode: 可选,文件打开模式
- buffering: 设置缓冲
- encoding: 一般使用utf8
- errors: 报错级别
- newline: 区分换行符
- closefd: 传入的file参数类型
- opener: 设置自定义开启器,开启器的返回值必须是一个打开的文件描述符。
模式 | 描述 |
t | 文本模式 (默认)。 |
x | 写模式,新建一个文件,如果该文件已存在则会报错。 |
b | 二进制模式。 |
+ | 打开一个文件进行更新(可读可写)。 |
U | 通用换行模式(不推荐)。 |
r | 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。 |
rb | 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。一般用于非文本文件如图片等。 |
r+ | 打开一个文件用于读写。文件指针将会放在文件的开头。 |
rb+ | 以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。一般用于非文本文件如图片等。 |
w |
打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。 |
wb | 以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。 |
w+ | 打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。 |
a | 打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
ab | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
a+ | 打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。 |
ab+ | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。 |
默认打开为文本模式,如果要以二进制模式打开,要加上 b 。
#A代表一个字符
ascii:
A : 00000010 8位 一个字节(代表一个字符)unicode :
A : 00000010 00000010 00000010 00000010 32位 四个字节
中 :00000010 00000010 00000010 00000010 32位 四个字节
utf-8:
A :00000010 8位 一个字节
中:00000010 00000010 00000010 24位 三个字节
gbk:
A :00000010 8位 一个字节
中:00000010 00000010 16位 两个字节1、各个编码之间的二进制是不能相互识别的,会产生乱码。
2、文件的储存,传输,不能是Unicode(只能是utf-8,utf-16,gbk,gb231等)python3中:
str 在内存中使用Unicode编码。
bytes类型
对于英文:
str : 表现形式:s = ‘zhou’
编码形式:010101010 unicode
bytes:表现形式:s = b’zhou‘
编码方式:000101010 utf-8,gbk…………对于中文 :
str : 表现形式:s = ‘中国’
编码形式:010101010 unicode
bytes:表现形式:s = b'\xe4\xb8\xad\xe5\x9b\xbd' (utf-8)
编码方式:000101010 utf-8,gbk………
序号 | 方法及描述 |
---|---|
常用函数 | |
1 | file.close() 关闭文件。关闭后文件不能再进行读写操作 |
2 | file.read([size]) 从文件读取指定的字节数,如果未给定或为负则读取所有。 |
3 | file.readline([size]) 读取整行,包括 "\n" 字符。 |
4 | file.readlines([sizeint]) 读取所有行并返回列表,若给定sizeint>0,则是设置一次读多少字节,这是为了减轻读取压力。 |
5 | file.seek(offset[, whence]) 设置文件当前位置(设置光标的位置方便读取) |
6 | file.tell() 返回文件当前位置。(或者叫做返回光标的位置) |
7 | file.write(str) 将字符串写入文件,返回的是写入的字符长度。 |
8 | file.writelines(sequence) 向文件写入一个序列字符串列表,如果需要换行则要自己加入每行的换行符。 |
不常用函数 | |
9 | file.fileno() 返回一个整型的文件描述符(file descriptor FD 整型), 可以用在如os模块的read方法等一些底层操作上。 |
10 | file.flush() 刷新文件内部缓冲,直接把内部缓冲区的数据立刻写入文件, 而不是被动的等待输出缓冲区写入。 |
11 | file.truncate([size]) 截取文件,截取的字节通过size指定,默认为当前文件位置。 |
12 | file.isatty() 如果文件连接到一个终端设备返回 True,否则返回 False。 |
13 | file.next() 返回文件下一行。 |
用方法一每次都要调用 close() 的方法来关闭文件实在太繁琐(就是不想写)
所以Python 引入了 with 语句来自动帮我们调用 close() 方法(即会自动关闭文件)
由于文件读写时都有可能产生 IOError,一旦出错,后面的 f.close() 就不会调用。所以,为了保证无论是否出错都能正确的关闭文件,可以使用 try...finally 来实现
try:
f = open('/path/to/file', 'r')
print(f.read())
finally:
if f:
f.close()
感谢各位友友能够看到这里:
在鲁迅一篇未发表的文章中说过:“代码看懂了不是懂✨一定要自己实际操作哇✨这样才能更好的理解和吸收。”
最后来一句:一个人可以在任何他怀有无限热忱的事情上成功,让我们一起进步吧✨✨