移动测试基础 [Share]解决 HTMLTestRunner 中文显示乱码的问题

唐僧之妈 · 2014年10月11日 · 最后由 hctaler 回复于 2014年12月24日 · 2770 次阅读

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

问题解释

很多人在使用 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.再次运行你的测试脚本

现象截图

修改前
修改前

修改后
修改后

其他

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

共收到 9 条回复 时间 点赞

有用,谢分享

应该是 HTMLTeatRunner 的第 766 和 772 行吧 我用的 0.82 版本

#2 楼 @kyotokyoking 我是基于 Github 上最新的源码

#3 楼 @xiaomayi0323 错误信息折行的问题有什么好的解决方案吗

#4 楼 @kyotokyoking 这两天有点忙,还没有 Research

#5 楼 @xiaomayi0323 研究下了 脚本信息显示是在 488-490 行之间使用 pre 标签,在网上找了些换行的方法,并实践,但未达到效果。

不错哦

#6 楼 @kyotokyoking 显示出界的问题,想了一个笨办法,既然不能强制折行,那就把背后的区域放大,让它看起来没有出界,不就 OK 了嘛,算是变相解决吧,具体看我新发的帖子

可以在读取文件时候这样写就可以显示中文了
rd=f.readline().decode('utf-8')

需要 登录 后方可回复, 如果你还没有账号请点击这里 注册