这是一个创建于 3646 天前的主题,其中的信息可能已经有所发展或是发生改变。
新学python,由于想减轻工作中重复劳动,撸了个自动生成Excel的代码。问题就出在这里了
本人的环境是pyside + py32com + beautifulsoup + python2.7, windows下面
先看代码,这里是Pyside Main窗体的一段代码:
try:
self.genbtn.setText(u"稍后...")
self.genbtn.update()
sprm.report() #开始生成报告
#threading.Thread(target=sprm.report).start() #多线程运行有错
except StandardError,e: #如果文档打开有误
QtGui.QMessageBox.information(None,u"前方高能", e.message)
---------------------------------------------------------------------------------------
以上代码能正常运行并出现我想要的结果,但如果把sprm.report()这个注释掉用多线程的代码就出错,下面是出错的地方,也就是sprm.report 里调用的一个方法:
self.xlApp = win32com.client.DispatchEx("Excel.Application")
-----------------------------------------------------------------------------------------
这段代码不能在多线程里运行也就算了,但TM的之前我这样用的确能正确运行,还测试过好几次,后来为一些代码添加了一些注释改了零碎的东西后,就TM的运行不了。真是无解。
再顺便再问一问,多线程的异常怎样在UI线程(主线程)中捕获,我的代码在多线程中raise了后,exception 就抓不到raise的,但单线程能捕获。