我搞不懂为什么信号不起作用。在PyQt5中,这段代码起作用(区别在于它不是信号,而是pyqtSignal)。
当您单击按钮时,TextEdit应该显示“连接到设备”的消息,如果用pyqt替换pyside,代码将正常工作。
import sys
from PySide6.QtCore import *
from PySide6.QtWidgets import *
class Ui_MainWindow(object):
def setupUi(self, MainWindow):
if not MainWindow.objectName():
MainWindow.setObjectName(u"MainWindow")
MainWindow.resize(188, 267)
self.centralwidget = QWidget(MainWindow)
self.centralwidget.setObjectName(u"centralwidget")
self.pushButton = QPushButton(self.centralwidget)
self.pushButton.setObjectName(u"pushButton")
self.pushButton.setGeometry(QRect(50, 140, 75, 24))
self.textEdit = QTextEdit(self.centralwidget)
self.textEdit.setObjectName(u"textEdit")
self.textEdit.setGeometry(QRect(30, 40, 104, 71))
MainWindow.setCentralWidget(self.centralwidget)
self.retranslateUi(MainWindow)
QMetaObject.connectSlotsByName(MainWindow)
def retranslateUi(self, MainWindow):
MainWindow.setWindowTitle(QCoreApplication.translate("MainWindow", u"MainWindow", None))
self.pushButton.setText(QCoreApplication.translate("MainWindow", u"PushButton", None))
class MainWindow(QMainWindow):
def __init__(self):
QMainWindow.__init__(self, parent=None)
self.dragPos = None
self.ui = Ui_MainWindow()
self.ui.setupUi(self)
self.show()
def update_text(value, textEdit):
textEdit.setText(textEdit.toPlainText() + value)
textEdit.verticalScrollBar().setValue(textEdit.verticalScrollBar().maximum())
class account(QThread):
textUpdate = Signal(str, QTextEdit)
def __init__(self):
super().__init__(parent=None)
self.textUpdate.connect(update_text)
def run(self):
print("thread is work")
self.textUpdate.emit("Connect to device\n", ui.textEdit)
if __name__ == "__main__":
app = QApplication()
acc_instance = account()
main = MainWindow()
ui = main.ui
ui.pushButton.clicked.connect(acc_instance.start)
sys.exit(app.exec_())我知道覆盖run方法是不正确的。
P.S.S .增加了一个小例子
发布于 2021-04-23 19:26:36
您的代码有几个问题:
但是在这种情况下,我不认为需要发送QTextEdit,而只需要发送数据,然后修改GUI来设置它,因为这是它的任务。
class MainWindow(QMainWindow):
def __init__(self, parent=None):
QMainWindow.__init__(self, parent)
self.ui = Ui_MainWindow()
self.ui.setupUi(self)
@Slot(str)
def update_text(self, value):
self.ui.textEdit.setText(self.ui.textEdit.toPlainText() + value)
self.ui.textEdit.verticalScrollBar().setValue(
self.ui.textEdit.verticalScrollBar().maximum()
)
class Account(QThread):
textUpdate = Signal(str)
def run(self):
print("thread is work")
self.textUpdate.emit("Connect to device\n")
if __name__ == "__main__":
app = QApplication()
main = MainWindow()
acc_instance = Account()
acc_instance.textUpdate.connect(main.update_text)
main.ui.pushButton.clicked.connect(acc_instance.start)
main.show()
sys.exit(app.exec_())注意:在pyqt6中,您的初始代码也不能工作。
如果要向多个QTextEdit发送文本,最好创建一个键,将每种类型的文本关联到QTextEdit组:
from collections import defaultdict
from functools import cached_property
class MainWindow(QMainWindow):
def __init__(self):
QMainWindow.__init__(self, parent=None)
self.dragPos = None
self.ui = Ui_MainWindow()
self.ui.setupUi(self)
self.show()
self.register("device_viewer", self.ui.textEdit)
# self.register("another_key", another_textedit)
def register(self, key, textedit):
if not isinstance(textedit, QTextEdit):
raise TypeError(f"{textedit} must be a QTextEdit")
self.registry_viewers[key].append(textedit)
@cached_property
def registry_viewers(self):
return defaultdict(list)
@Slot(str, str)
def update_text(self, key, value):
for textedit in self.registry_viewers[key]:
textedit.setText(textedit.toPlainText() + value)
textedit.verticalScrollBar().setValue(
textedit.verticalScrollBar().maximum()
)
class Account(QThread):
textUpdate = Signal(str, str)
def run(self):
print("thread is work")
self.textUpdate.emit("device_viewer", "Connect to device\n")
# self.textUpdate.emit("another_key", "message")
if __name__ == "__main__":
app = QApplication()
main = MainWindow()
acc_instance = Account()
acc_instance.textUpdate.connect(main.update_text)
main.ui.pushButton.clicked.connect(acc_instance.start)
sys.exit(app.exec_())https://stackoverflow.com/questions/67231753
复制相似问题