在 setupUI 中连接 QListWidgetItem [重复]

Posted

技术标签:

【中文标题】在 setupUI 中连接 QListWidgetItem [重复]【英文标题】:Connect QListWidgetItem in setupUI [duplicate] 【发布时间】:2019-06-19 19:48:18 【问题描述】:

我想将文件拖放到listwidget,当itemactivatedplaintextedit 打开并且文件中的readAll 行时。但返回错误:"connect() failed between itemActivated(QListWidgetItem*) and read_txt()"

from PyQt5 import QtCore, QtGui, QtWidgets
import sys


class Ui_MainWindow(object):

    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(873, 663)
        self.centralwidget = QtWidgets.QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")
        MainWindow.setCentralWidget(self.centralwidget)

        self.listWidget = listWidget(self.centralwidget)
        self.listWidget.setGeometry(QtCore.QRect(150, 330, 256, 192))
        self.listWidget.setObjectName("listWidget")

        self.plainTextEdit = QtWidgets.QPlainTextEdit(self.centralwidget)
        self.plainTextEdit.setGeometry(QtCore.QRect(440, 200, 104, 87))
        self.plainTextEdit.setObjectName("plainTextEdit")

        self.listWidget.itemActivated.connect(self.read_txt)

        QtCore.QMetaObject.connectSlotsByName(MainWindow)

    @QtCore.pyqtSlot("QListWidgetItem*")
    def read_txt(self,links):

        file = QtCore.QFile(links.text())
        if file.open(QtCore.QFile.ReadOnly | QtCore.QFile.Text):
            self.plainTextEdit.setPlainText(file.readAll().data().decode())            
class listWidget(QtWidgets.QListWidget):
    def __init__(self, parent):
        super().__init__(parent)   
        self.setAcceptDrops(True)

    def dragEnterEvent(self, event):

        if event.mimeData().hasUrls:

            event.acceptProposedAction()
        else:
            event.ignore() 

    def dragMoveEvent(self, event):
        if event.mimeData().hasUrls:
            event.setDropAction(QtCore.Qt.CopyAction)
            event.acceptProposedAction()
        else:
            event.ignore()
    def dropEvent(self, event):

        if event.mimeData().hasUrls:
            event.setDropAction(QtCore.Qt.CopyAction)

            for url in event.mimeData().urls():
                links=QtWidgets.QListWidgetItem(url.toLocalFile())

            self.addItem(links)
            event.acceptProposedAction()   


if __name__ == "__main__":


    if not QtWidgets.QApplication.instance():
        app = QtWidgets.QApplication(sys.argv)
    else:
        app = QtWidgets.QApplication.instance() 



    MainWindow = QtWidgets.QMainWindow()
    ui = Ui_MainWindow()
    ui.setupUi(MainWindow)
    MainWindow.show()
    app.exec_() 

拖放工作正常,但无法将QListWidgetItemsetupUi 中的readtxt 方法连接起来。有什么问题??

【问题讨论】:

【参考方案1】:

问题是@pyqtSlot 装饰器只能在继承自QObject 的类中使用。您可以将信号连接到任何可调用对象,因此最简单的方法是省略装饰器,但如果出于某种原因确实需要它,您可以继承 QMainWindow 并在其中定义插槽,例如

class MyMainWindow(QtWidgets.QMainWindow):
    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        self.ui = Ui_MainWindow()
        self.ui.setupUi(self)
        self.ui.listWidget.itemActivated.connect(self.read_txt)

    @QtCore.pyqtSlot("QListWidgetItem*")
    def read_txt(self, links):
        file = QtCore.QFile(links.text())
        if file.open(QtCore.QFile.ReadOnly | QtCore.QFile.Text):
            self.ui.plainTextEdit.setPlainText(file.readAll().data().decode())


if __name__ == '__main__':
    ...
    mainWindow = MyMainWindow()
    mainWindow.show()
    ...

【讨论】:

Mainwindow 中定义插槽有效,但是当我在Ui_MainWindow 中定义它时,就像在我的问题中一样并删除了装饰器,仍然无法readAll。我没有完全理解在MainwindowUi_MainWindow 下定义插槽之间的区别。 @scorp 只有像小部件(QWidget、QDialog、QMainWindow 等)这样的 QObject 支持 pyqtSlot,因为它们使用 QMetaObject。你应该阅读riverbankcomputing.com/static/Docs/PyQt5/…和riverbankcomputing.com/static/Docs/PyQt5/signals_slots.html

以上是关于在 setupUI 中连接 QListWidgetItem [重复]的主要内容,如果未能解决你的问题,请参考以下文章

在 setupUI 中连接 QListWidgetItem [重复]

将 QMainWindow 与 Qdialog 小部件连接起来

QListWidget:项目点击事件

ui->setupUi(this) 的作用

QListWidget 不会自行调整大小

在 QListWidget 中使用自定义 QListWidgetItems