解决python3运行selenium下HTMLTestRunner报错的问题
修改htmltestrunner.py以支持python3+
搜索到的结果整理
修改一: 在python shell里输入 >>>import htmltestrunner >>> dir(htmltestrunner) 发现不认识stringio (no module named stringio)
确实3里面没有这个了,第94行引入的名称要改,改成import io,539行要改成self.outputbuffer = io.bytesio()
修改二: 运行程序的时候有报错,attributeerror: ‘dict' object has no attribute ‘has_key' 发现has_key的又被k掉了
到642行去做修改,if not rmap.has_key(cls): 需要换成 if not cls in rmap: (修改的时候换行、空格等不要改掉原有的格式)
修改三: 运行,继续有报错:'str' object has no attribute ‘decode'
好像是3里面对字符的操作,decode已经拿掉了。定位一下,报在了772行,ue = e.decode(‘latin-1'),那么不需要decode操作了吧,直接改成 ue = e ,另外766还有类似的uo = o.decode(‘latin-1'),可不动先留着;
打开本地文件需用 fp = open(filename,'wb'),不要再去用file了;关闭该文件可用fp.close()
修改四: 继续运行,发现还是在纠结数据类型的错: output = saxutils.escape(uo+ue), typeerror: can't concat bytes to str
bytes和str不能直接连起来,那么778行的内容escape(uo+ue) 有一个处理的“笨办法”:都改成str,可修改该处内容为escape(str(uo)+ue)
修改五:(此处是最后一处改动了) 程序已然运行大半,但是最后还是有error: print >>sys.stderr, ‘\ntime elapsed: %s' % (self.stoptime-self.starttime) typeerror: unsupported operand type(s) for >>: ‘builtin_function_or_method' and ‘rpcproxy'
到631行,把print的语句修改掉,改成 print (sys.stderr, ‘\ntime elapsed: %s' % (self.stoptime-self.starttime))
以上这篇解决python3运行selenium下htmltestrunner报错的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
推荐阅读
-
解决virtualenv -p python3 venv报错的问题
-
Xcode8下iOS10常见报错闪退,字体适配和编译不过的问题及解决方案
-
Xcode8下iOS10常见报错闪退,字体适配和编译不过的问题及解决方案
-
win7下docker安装与报错问题的解决方法
-
使用cmd运行mysql数据库的时候,报错:"不是内部命令也不是可有运行的程序"问题的解决办法
-
解决python3 HTMLTestRunner测试报告中文乱码的问题
-
win7下docker安装与报错问题的解决方法
-
解决python3中自定义wsgi函数,make_server函数报错的问题
-
解决python3 安装完Pycurl在import pycurl时报错的问题
-
有关xerosploit运行报错问题的有效解决方案