在 setupUI 中连接 QListWidgetItem [重复]
Posted
技术标签:
【中文标题】在 setupUI 中连接 QListWidgetItem [重复]【英文标题】:Connect QListWidgetItem in setupUI [duplicate] 【发布时间】:2019-06-19 19:48:18 【问题描述】:我想将文件拖放到listwidget
,当itemactivated
、plaintextedit
打开并且文件中的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_()
拖放工作正常,但无法将QListWidgetItem
与setupUi
中的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
。我没有完全理解在Mainwindow
和Ui_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 [重复]