您好,登錄后才能下訂單哦!
修改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報錯的問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。