解决:ValueError: binary mode doesn‘t take an encoding argument
文章目录
- 解决:ValueError: binary mode doesn‘t take an encoding argument
- 背景
- 报错问题
- 报错翻译
- 报错位置代码
- 报错原因
- 解决方法
- 方法一
- 方法二
- 今天的分享就到此结束了
背景
在使用之前的代码时,报错:
Traceback (most recent call last):
File , line 1, in
with open(file_path, ‘wb’, encoding=‘utf-8’) as f:
ValueError: binary mode doesn‘t take an encoding argument
报错问题
Traceback (most recent call last): File , line 1, in with open(file_path, 'wb', encoding='utf-8') as f: ValueError: binary mode doesn‘t take an encoding argument
报错翻译
主要报错信息内容翻译如下所示:
Traceback (most recent call last): File , line 1, in with open(file_path, 'wb', encoding='utf-8') as f: ValueError: binary mode doesn‘t take an encoding argument
翻译:
回溯(最近一次调用最后一次): with open(file_path, 'wb', encoding='utf-8') as f: 中的文件 “”,第 1 行
ValueError:二进制模式不采用编码参数
报错位置代码
...with open(file_path, 'wb', encoding='utf-8') as f:data = f.read()
...
代码截图如下:
报错原因
经过查阅资料,发现是使用open()
方法,参数mode = "rb"时,rb+操作时不支持指定encoding参数。
附:不同模式打开文件的参数列表如下:
模式 | 描述 |
---|---|
t | 文本模式 (默认)。 |
x | 写模式,新建一个文件,如果该文件已存在则会报错。 |
b | 二进制模式。 |
+ | 打开一个文件进行更新(可读可写)。 |
U | 通用换行模式(不推荐)。 |
r | 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。 |
rb | 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。一般用于非文本文件如图片等。 |
r+ | 打开一个文件用于读写。文件指针将会放在文件的开头。 |
rb+ | 以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。一般用于非文本文件如图片等。 |
w | 打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。 |
wb | 以二进制格式打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。 |
w+ | 打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。 |
wb+ | 以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。 |
a | 打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
ab | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
a+ | 打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。 |
ab+ | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。 |
小伙伴们按下面的解决方法即可解决!!!
解决方法
要解决这个错误,有两种解决方法
方法一
需要先读取数据,再进行数据encoding解码。
正确的代码是:
data = open(file_path, 'wb').read().decode(encoding='utf-8')
截图如下:
方法二
需要把“wb”改成“w”,也就是原来以二进制的格式写入的file,改为用string类型写入。
正确的代码是:
with open(file_path, 'w', encoding='utf-8') as f:data = f.read()
截图如下: