首先只要遇到提示GBK、UTF-8或乱码显示字样等,这些肯定是编码问题。为了解决问题还特意了解了下UTF-8 与GBK之间的区别和关系 。修改file.encoding系统变量编码为UTF-8
问题情景:
python脚本已经调通过的自动化项目,部署到Jenkins上后,使用jenkins构建,控制台print输出报错,如下图:
控制台输出:
分析问题:
我们知道,windows的控制台默认编码就是'GBK',而我们代码编码格式是utf-8,因为Jenkins会默认读取当前系统的编码格式,这样就会导致Jenkins构建时中文乱码或报GBK转码问题,如上图的报错问题:'\u20ac'实际就是特殊字符'€'的转码格式。所以一切都是windows的控制台默认编码GBK问题。哪么我们知道,只要统一他的读写格式,省去Jenkins与python中间转码哪就能解决这个问题。
搜索解决办法:
果断百度一下,按照设置全局配置那里设置LANG :zn_CH.utf-8 ,结果无效。
查看了一下,系统管理--->系统信息--->系统属性的第三行可以看到系统编码格式为GBK。
注解:
file.encoding主要管理的是文件中的编码
sun.jnu.encoding 主要负责文件名类的编码
网上查了下,大部分是说这个是java层面的编码问题,所以在jenkins 里设置半天并没效果下。所以查了下file.encoding、sun.jnu.encoding 的GBK编码修改成UTF-8的方法,如下:
在操作系统变量里添加启动参数:
1.打开环境变量设置
2.注意是新建,不是在什么path中新加,
直接新建一个变量名为JAVA_TOOL_OPTIONS
变量值为 -Dfile.encoding=UTF-8 -Dsun.jnu.encoding=UTF-8
保存后并重启Jenkins(重启命令:restart)
查看Jenkins系统属性果真修改成功了。但是新问题又来了,我重新构建了下我的项目发现仍然报错,而且还出现了中文乱码。
最终解决办法:
后面我想了下,网上大部分是说这个是java层面的编码问题,哪可能是他们的自动化项目本来就是Java所写呀,所以我以上操作只能针对Java项目的编码。对于 python自动化测试项目在jenkins 里构建并没有效果。同理,我们添加一个Python变量就可以了。
在操作系统变量里添加启动参数:
1.打开环境变量设置
2.注意是新建,不是在什么path中新加,
直接新建一个变量名为PYTHONIOENCODING
变量值为 UTF8
好了,重启Jenkins就可以啦,快构建试试吧
注意:PYTHONIOENCODING这个变量是最主要的