pytest报错UnicodeDecodeError: ‘gbk‘ codec can‘t decode

文章讲述了在遇到gbk编码错误时的解决方法,重点检查了pytest.ini配置文件中的中文问题,并提出在报错文件末尾添加encoding=utf-8的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

UnicodeDecodeError: 'gbk' codec can't decode byte 0xaf in position 129: illegal multibyte sequence

 上面就是我的报错,试了好多次,看了好多篇文章,终于看到了福音,解决的办法

第一、这时候看一下你们pytest.ini文件中是不是又中文我的就是中文

第二,找到你报错的倒数第二行报错,点击,打开,需要早再后面加一下就可以解决了  

, encoding='utf-8'

### 问题分析与解决方案 在运行 pytest 时出现 `UnicodeDecodeError: 'utf-8' codec can't decode byte` 错误,通常是由于 Python 在读取文件时遇到非 UTF-8 编码的内容,而默认情况下 Python 在 Linux 系统(如 Ubuntu)中使用 UTF-8 编码。以下是针对该问题的详细分析和解决方案。 #### 1. **问题根源** Python 中的 `open` 方法在不同操作系统中的默认编码方式存在差异: - 在 Windows 系统中,默认编码为 GBK。 - 在 Linux 系统(如 Ubuntu)中,默认编码为 UTF-8。 如果项目中某些文件是以 GBK 编码保存的,而 pytest 在 Ubuntu 环境下运行时尝试以 UTF-8 编码读取这些文件,则会引发 `UnicodeDecodeError` 错误[^1]。 #### 2. **解决方法** ##### 方法一:修改 iniconfig 模块的编码方式 通过调整 iniconfig 模块的默认编码方式,可以避免 pytest 在读取配置文件时因编码不匹配导致的错误。 具体步骤如下: 1. 找到 iniconfig 模块下的 `__init__.py` 文件。可以通过以下命令定位: ```bash find /usr -name "__init__.py" | grep iniconfig ``` 2. 打开该文件,在第 52 行左右找到 `open` 方法调用的位置,添加 `encoding="gbk"` 参数。例如: ```python with open(path, encoding="gbk") as f: content = f.read() ``` 这种方法适用于临时解决问题,但可能会导致兼容性问题,建议谨慎使用。 ##### 方法二:转换文件编码为 UTF-8 将所有相关文件从 GBK 编码转换为 UTF-8 编码,确保 pytest 在运行时不会因编码冲突报错。可以使用 Python 的 `codecs` 库实现编码转换: ```python import codecs file_path = "example.txt" # 原始文件路径 new_file_path = "example_utf8.txt" # 转换后的文件路径 with codecs.open(file_path, 'r', encoding='GBK') as f: content = f.read() with codecs.open(new_file_path, 'w', encoding='utf-8') as f: f.write(content) ``` 此方法能够从根本上解决问题,推荐优先使用[^3]。 ##### 方法三:设置系统默认编码为 GBK 可以通过修改环境变量或 Python 配置文件的方式,将系统默认编码设置为 GBK。例如,在 pytest 运行前设置以下环境变量: ```bash export PYTHONIOENCODING=gbk pytest ``` 或者在项目的 `pytest.ini` 文件中添加以下内容: ```ini [pytest] addopts = --tb=native python_files = *.py python_classes = Test* python_functions = test_* ``` 同时确保 pytest 在运行时正确加载了配置文件。 #### 3. **实验验证** 以下代码可用于测试不同编码方式对文件读取的影响: ```python for path in ["utf8File.txt", "gbkFile.txt"]: for encoding in [None, 'utf-8', 'gbk']: try: with open(path, encoding=encoding) as f: print(f.read()) break except UnicodeError as e: print(e) ``` 运行结果可以帮助确认文件的实际编码格式,并选择合适的解决方案。 --- ###
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值