2015-12-18 88 views
3

我有三个Python(3.4.3)脚本。其中之一是控制由PyQt5生成的.ui文件。当我运行GUI程序时,它接受所有数据和所有内容,并且当我按下InputDialog上的OK按钮时,窗口关闭并显示控制台。python:使用PyCharm和PyQt5完成退出代码1的过程

Process finished with exit code 1

当我运行的Python IDLE相同的代码,它显示:

<<<<<<RESTART>>>>>>

,当我用这个相同的Python(3.4.3或2.7)上的标识码这绝不happenned工作室。可能是什么原因?

这里是控制.ui文件的python文件的代码。

import sys 
from PyQt5 import QtCore, QtGui, uic, QtWidgets 
from Email import encrypt_email 
from Email import decrypt_email 
from Email import newuser 

qtCreatorFile = "rsegui.ui" # Enter file here. 

Ui_MainWindow, QtBaseClass = uic.loadUiType(qtCreatorFile) 

class MyApp(QtWidgets.QMainWindow, Ui_MainWindow): 
    def __init__(self): 
     QtWidgets.QMainWindow.__init__(self) 
     Ui_MainWindow.__init__(self) 
     self.setupUi(self) 
     user, ok = QtWidgets.QInputDialog.getText(self, 'New User', 
    'Are you a new user?') 
     user=str(user) 
     if user in "YESYesyesYy": 
      email, ok = QtWidgets.QInputDialog.getText(self, 'New User', 
    'Enter Your Email ID:') 
      email1=str(email) 
      self.sender.setText(email) 
      newuser(email1) 

    self.encrypt_and_send.clicked.connect(self.EncryptEmail) 
    self.decrypt.clicked.connect(self.DecryptEmail) 
    self.clear.clicked.connect(self.ClearEncrypt) 
    self.clear_2.clicked.connect(self.ClearDecrypt) 
    self.sender.setPlaceholderText("Your Email ID") 
    self.receiver.setPlaceholderText("Receivers, Separate them by ';'") 
    self.subject.setPlaceholderText("Enter Subject") 
    self.message.setPlaceholderText("Enter Message") 
    self.sender_2.setPlaceholderText("Your Email ID") 
    self.message_2.setPlaceholderText("Encrypted Text") 



    def EncryptEmail(self): 
     sender = str(self.sender.text()) 
     receiver = str(self.receiver.text()) 
     receivers = receiver.split(';') 
     subject = str(self.subject.text()) 
     message = str(self.message.text()) 
     password, ok = QtWidgets.QInputDialog.getText(self, 'Password', 
'Enter your password:',QtWidgets.QLineEdit.Password) 
     encrypt_email(sender,receivers,subject,message,password) 

    def DecryptEmail(self): 
     email = str(self.sender_2.text()) 
     message = str(self.message_2.text()) 
     self.decrypted.setText(decrypt_email(email,message)) 

    def ClearDecrypt(self): 
     self.sender_2.clear() 
     self.message_2.clear() 

    def ClearEncrypt(self): 
     self.sender.clear() 
     self.message.clear() 
     self.receiver.clear() 
     self.subject.clear() 

if __name__ == "__main__": 
    app = QtWidgets.QApplication(sys.argv) 
    window = MyApp() 
    window.show() 
    sys.exit(app.exec_()) 
+0

非常好的问题。既然它涉及代码,我认为它可能是一个好主意,提供一些,你不觉得吗?此外,追溯也将非常有用! –

+0

我用代码更新了问题。没有追踪被打印到控制台。 – daipayan

+0

@ N.Wouda任何想法为什么会发生这种情况? – daipayan

回答

14

我处理过同样的问题,得到的答复是双重的:

  1. 它的崩溃可以是任何一些事情的原因。这可能是一个编程错误,调用一个不存在的函数,传递一个小部件而不是布局等等。但是由于你没有得到有用的输出,你不知道在哪里寻找罪魁祸首。这是由于:
  2. PyQT引发和捕获异常,但不会传递它们。相反,它只是以1的状态退出,以显示异常被捕获。

要捕捉到的异常,你需要覆盖SYS异常处理程序:

# Back up the reference to the exceptionhook 
sys._excepthook = sys.excepthook 

def my_exception_hook(exctype, value, traceback): 
    # Print the error and traceback 
    print(exctype, value, traceback) 
    # Call the normal Exception hook after 
    sys._excepthook(exctype, value, traceback) 
    sys.exit(1) 

# Set the exception hook to our wrapping function 
sys.excepthook = my_exception_hook 

然后在你的执行代码,在一个try/catch包裹。

try: 
    sys.exit(app.exec_()) 
except: 
    print("Exiting") 
+0

在try-except块中包装app.exec_的目的是什么? –

+0

我真的不确定是否有必要,但这是我的实施如何结束。尝试没有,它可能不需要。 – IronSean