问题描述:
最近在使用Python执行JS文件时,遇到了一个报错:“ UnicodeDecodeError: 'gbk' codec can't decode byte 0xa8 in position 34: illegal multibyte sequence
”。尽管已经在打开文件时指定了编码格式为utf-8: js_code = open("get_m.js", mode="r", encoding="utf-8").read()
,但问题仍然存在。
问题解决:
回想起之前解决中文乱码问题的经验,我考虑到可能是在导入execjs模块之前,系统对编码格式进行了默认设置,导致了这个报错。因此,我决定在导入execjs模块之前,强制指定Popen的编码格式为utf-8。
解决方式:
在代码文件的开头加入以下内容:
import subprocess
from functools import partial # 用来固定某个参数的固定值
subprocess.Popen = partial(subprocess.Popen, encoding='utf-8')
# 解决execjs执行js时产生的乱码报错,需要在导入execjs模块之前,让Popen的encoding参数锁定为utf-8
import execjs
通过这样的修改,成功解决了执行JS文件时出现的UnicodeDecodeError报错,虽然具体原因尚不清楚,但这个方法有效地解决了问题。