python,用cxfreeze制作无控制台(console)应用程序,很多博客都教我们用base=win32gui参数。

但,在我的实际使用中,发现有一个使用pyqt的小应用程序,用base=console打包就正常,用base=win32gui就不正常运行。

  不知道跟pyqt是否有关系。

经过长时间的debug,发现问题出在最简单的 print 上。

 

python的print其实是(大概)调用 sys.stdout.write()。

用base=console打包后,这个sys.stdout是指向console的框框中的,但用base=win32gui打包后,估计是把这个print后的信息直接扔掉了。

然而我的程序内部的错误却是 IOerror('9', 'BAD FILE DExxxxxx') 

发现,print一个小字符串就没问题,但,print的字符串太长(或者累积数量太大?)就会发生这个问题。

 

 

解决方法:

既然print是调用sys.stdout.write(),如果不需要这些信息,就建一个子类

  xxxxxxxxxxxx

  class _ignore():

    def write(self,obj):

      return

然后在自己主函数的init初加入 sys.stdout = self._ignore() 即可。

也可以写到文件中,这样更简单,加一句sys.stdout = open(filename,'w')就行。

 

 

我觉得win32gui应该会自己帮我把sys.stdout指向一个空输出,就像我现在一样才对。

我在网上找不到这个解决方案,记载下来方便以后遇上的人。