从 PyQt 中的外部 GUI 类访问 GUI 元素

Xon*_*hiz 5 pyqt pyqt4 qt-designer python-2.7 pyuic

注意:我已经读过这篇文章,但不幸的是我没有理解它。我的目录设置有点像这样:

Main_Folder
|_ Base_Gui_File.py
|_ Child_directory (a directory inside Main_Folder)
  |_ __init__.py
  |_ some_other.py
Run Code Online (Sandbox Code Playgroud)

Base_Gui_File.py我已经在文件中找到了从(PyQt4)生成的所有 GUI 代码designer。有一个文本输入字段QLineEdit、一个按钮QPushButton和一个文本区域QTextBrowser

默认情况下QTextBrowser是隐藏的。但是,我想做的是,当有人在 中键入某些内容QLineEdit并单击 时QPushButton,它会将字符串发送到 中文件中的QLineEdit方法。在对该字符串执行某些操作后,文件中的方法将在中打印一些内容。some_other.pyChild_Directorysome_other.pyshowQTextBrowserBase_Gui_File.pyQTextBrowser

到目前为止,我已经能够Base_GUI_File.py通过some_other.pyQLineEdit. 这是两个文件的代码:

some_other.py

import sys
sys.path.append("..")
from Base_Gui_File import Ui_MainWindow


class childone(object):
    """docstring for childone"""
    def __init__(self):
        super(childone, self).__init__()

    def somemethod(self, url):
        pass
        print 'Hey!'
        final_string = str(url) + "Just tying this!"
        print final_string
Run Code Online (Sandbox Code Playgroud)

Base_Gui_file.py

# -*- coding: utf-8 -*-

from PyQt4 import QtCore, QtGui

try:
    _fromUtf8 = QtCore.QString.fromUtf8
except AttributeError:
    def _fromUtf8(s):
        return s

try:
    _encoding = QtGui.QApplication.UnicodeUTF8
    def _translate(context, text, disambig):
        return QtGui.QApplication.translate(context, text, disambig, _encoding)
except AttributeError:
    def _translate(context, text, disambig):
        return QtGui.QApplication.translate(context, text, disambig)

class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        MainWindow.setObjectName(_fromUtf8("MainWindow"))
        MainWindow.resize(800, 544)
        self.centralwidget = QtGui.QWidget(MainWindow)
        self.centralwidget.setObjectName(_fromUtf8("centralwidget"))
        self.MyPushButton = QtGui.QPushButton(self.centralwidget)
        self.MyPushButton.setGeometry(QtCore.QRect(680, 40, 75, 23))
        self.MyPushButton.setObjectName(_fromUtf8("MyPushButton"))
        self.MyLabel = QtGui.QLabel(self.centralwidget)
        self.MyLabel.setGeometry(QtCore.QRect(30, 30, 46, 13))
        self.MyLabel.setObjectName(_fromUtf8("MyLabel"))
        self.MyTextArea = QtGui.QTextBrowser(self.centralwidget)
        self.MyTextArea.setGeometry(QtCore.QRect(20, 110, 721, 361))
        self.MyTextArea.setObjectName(_fromUtf8("MyTextArea"))
        self.MyTextField = QtGui.QLineEdit(self.centralwidget)
        self.MyTextField.setGeometry(QtCore.QRect(100, 30, 571, 41))
        self.MyTextField.setObjectName(_fromUtf8("MyTextField"))
        MainWindow.setCentralWidget(self.centralwidget)
        self.menubar = QtGui.QMenuBar(MainWindow)
        self.menubar.setGeometry(QtCore.QRect(0, 0, 800, 21))
        self.menubar.setObjectName(_fromUtf8("menubar"))
        self.menuFIle = QtGui.QMenu(self.menubar)
        self.menuFIle.setObjectName(_fromUtf8("menuFIle"))
        MainWindow.setMenuBar(self.menubar)
        self.statusbar = QtGui.QStatusBar(MainWindow)
        self.statusbar.setObjectName(_fromUtf8("statusbar"))
        MainWindow.setStatusBar(self.statusbar)
        self.menubar.addAction(self.menuFIle.menuAction())

        self.MyPushButton.clicked.connect(self.download_click)

        self.retranslateUi(MainWindow)
        QtCore.QMetaObject.connectSlotsByName(MainWindow)

    def retranslateUi(self, MainWindow):
        MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow", None))
        self.MyPushButton.setText(_translate("MainWindow", "PushButton", None))
        self.MyLabel.setText(_translate("MainWindow", "TextLabel", None))
        self.menuFIle.setTitle(_translate("MainWindow", "FIle", None))

    def download_click(self):
            self.MyTextArea.textCursor().insertHtml('Im HERE!') # This is working as it should
            url = str(self.MyTextField.text())

            from Child_directory.some_other import childone

            childone().somemethod(url)


if __name__ == "__main__":
    import sys
    app = QtGui.QApplication(sys.argv)
    MainWindow = QtGui.QMainWindow()
    ui = Ui_MainWindow()
    ui.setupUi(MainWindow)
    MainWindow.show()
    sys.exit(app.exec_())
Run Code Online (Sandbox Code Playgroud)

我怎样才能这样做呢?我两天前开始学习 GUI 和 OO 编程(Python),所以我对它还很陌生。所以,即使它只是一个正确方向的指南,那就太好了!

ekh*_*oro 2

正如我在您链接到的答案中所说:编辑 . 生成的模块始终是一个错误pyuic。它是一个静态模块,可以导入到主程序中。

另外,程序的当前结构看起来是向后的。主脚本应该位于顶层,所有模块应该位于其下面的包中。这将确保您不需要进行任何奇怪的sys.path操作来导入您自己的模块。结构应如下所示:

program
    |_  main.py
    |_  package
        |_  __init__.py
        |_  app.py
        |_  gui.py
        |_  utils.py
Run Code Online (Sandbox Code Playgroud)

您的main.py脚本应该非常简单,如下所示:

if __name__ == '__main__':

    import sys
    from package import app

    sys.exit(app.run())
Run Code Online (Sandbox Code Playgroud)

这样做非常重要,因为该脚本的路径将成为sys.path. 这意味着您可以在程序中的任何其他模块from package import xxx中执行此操作,并且导入将始终正常工作。

app模块应如下所示:

import sys
from PyQt4 import QtCore, QtGui
from package.gui import Ui_MainWindow
from package import utils

class MainWindow(QtGui.QMainWindow, Ui_MainWindow):
    def __init__(self, parent=None):
        super(MainWindow, self).__init__(parent)
        self.setupUi(self)
        self.MyPushButton.clicked.connect(self.download_click)

    def download_click(self):
        self.MyTextArea.textCursor().insertHtml('Hello World!')
        url = str(self.MyTextField.text())
        utils.some_func(url)

def run():    
    app = QtGui.QApplication(sys.argv)
    window = MainWindow()
    window.show()
    return app.exec_()
Run Code Online (Sandbox Code Playgroud)

请注意,我已将对 gui 模块所做的编辑移至应用程序模块中。该类MainWindow将拉入您在 Qt Designer 中添加的所有小部件,它们将成为类实例的属性。因此,一旦您重新安排了程序,您应该使用 重新生成 gui 模块pyuic