关于pytest 报错UnicodeDecodeError: ‘gbk‘ codec can‘t decode byte 0xa1 in position 290: illegal 解决方法

当遇到pytest运行时出现'gbk' codec无法解码的错误,可能是因为pytest.ini文件编码格式为GBK。解决方案包括使用PyCharm以GBK格式打开文件或在Windows环境下新建TXT文件转换编码后保存为pytest.ini。
摘要由CSDN通过智能技术生成

UnicodeDecodeError: 'gbk' codec can't decode byte 0xa1 in position 290: illegal
multibyte sequence

解决方法:可能是pytest.ini 文件的编码格式的问题,用pycharm打开,点击右下角选择 “GBK”就行,或者,如果是Windows中文版,复制pytest.ini文件的内容,然后删除原文件,新建一个TXT文本文件,将内容粘贴进去并保存即可。

pytest报错完整信息:

C:\Users\cf03-t\PycharmProjects\untitled>pytest test0.py
Traceback (most recent call last):
  File "d:\py3.7\lib\runpy.py", line 193, in _run_module_as_main
    "__main__", mod_spec)
  File "d:\py3.7\lib\runpy.py", line 85, in _run_code
    exec(code, run_globals)
  File "D:\py3.7\Scripts\pytest.exe\__main__.py", line 7, in <module>
  File "d:\py3.7\lib\site-packages\_pytest\config\__init__.py", line 180, in con
sole_main
    code = main()
  File "d:\py3.7\lib\site-packages\_pytest\config\__init__.py", line 136, in mai<

`pytest.ini` 文件是一个 pytest 测试框架用来自定义配置的文件,它通常包含测试运行的一些选项和规则。如果遇到 `UnicodeDecodeError: 'utf-8' codec can't decode byte 0xd1 in position 33: invalid continuation byte` 这样的错误,这通常意味着你在 `.ini` 文件中使用了非 UTF-8 编码的文本,而 pytest 预期的是 UTF-8 格式。 1. 首先,检查 `pytest.ini` 的编码设置。确保文件开头有一个明确的声明,比如 `# coding=utf-8` 或 `# -*- coding: utf-8 -*-`,告诉 Python 文件是以 UTF-8 编码的。 2. 如果文件没有明确指定编码,尝试用文本编辑器将文件另存为 UTF-8 编码格式,通常可以在文件菜单中的“另存为”选项中选择。 3. 清空文件,然后重新创建,确保从头开始编写配置,这样可以避免引入可能存在问题的旧字符。 4. 检查文件内容是否有非ASCII字符,特别是那些在UTF-8编码范围外的字符,如果有的话,可能需要替换或调整这些字符。 5. 如果是在 Windows 上,有时候文件可能会被自动设置为其他编码,可以尝试右键点击文件,选择“属性”,检查“编码”部分是否为 UTF-8。 6. 如果以上步骤都无法解决问题,可能是外部工具(如版本控制系统)导致的问题,确保这些工具也正确配置了文件编码。 相关问题: 1. 如何在Python中设置文件的编码? 2. 为何要在pytest.ini中明确指定编码? 3. Windows系统下如何查看和更改文件的编码?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值