解决 HTMLTestRunner 中文显示乱码的问题

转载地址:http://testerhome.com/topics/1468

问题解释

很多人在使用Python做自动化测试时都会用到Unittest测试框架,同时也会使用HTMLTestRunner来生成HTML格式的测试报告,但在生成的测试报告中如果存在中文时,会出现中文显示为乱码的现象,这是由于编码格式不一致所导致的问题。

解决方法

在Google中搜索了一会儿,没有发现与该问题相关的信息,Github上也没有相关的Issues和Pull requests,我觉得可能有四种情况,一是用的人报告中没有出现中文,二是遇到了并解决了但没有记录或分享出来,三是遇到了但未解决,最后还有一种可能是我的搜索方式不够好,以至于没搜到,总之现在可以通过下面的方法来解决该问题。

1.在自己的测试脚本中加入下面的代码并保存:

import sys
reload(sys)
sys.setdefaultencoding('utf-8')

2.打开HTMLTestRunner.py(基于Github上最新的代码),修改其中的第777行和第783行,将其中的编码“latin-1”修改为“utf-8”后保存,具体如下所示:

if isinstance(o,str):
    # TODO: some problem with 'string_escape': it escape \n and mess up formating
    # uo = unicode(o.encode('string_escape'))
    uo = o.decode('utf-8')
else:
    uo = o
if isinstance(e,str):
    # TODO: some problem with 'string_escape': it escape \n and mess up formating
    # ue = unicode(e.encode('string_escape'))
    ue = e.decode('utf-8')
else:
    ue = e

3.再次运行你的测试脚本

现象截图

修改前

修改前

修改后

修改后

其他

从截图中可以明显的看到错误信息显示出界,没有折行,该问题也在解决中。


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值