Python 从子类编辑选项卡名称

Python 从子类编辑选项卡名称,python,python-3.x,pyqt,pyqt5,qtabwidget,Python,Python 3.x,Pyqt,Pyqt5,Qtabwidget,我正试图让一个函数更改选项卡上列出的文本,但我很难确定如何正确引用选项卡 下面的代码可以工作,但由于注释掉了这一行,所以什么也不做。我知道该行中的“self”有问题(单击按钮时,取消对该行的注释会导致错误),但我不知道应该如何使其工作。我猜我的问题在于标签是由不同的类创建的,但是我希望能够打开多个标签,每个标签中都有相同的小部件(就像这段代码所做的那样)。我是否需要重新构造代码来实现这一点 from PyQt5.QtWidgets import (QMainWindow, QApplicatio

我正试图让一个函数更改选项卡上列出的文本,但我很难确定如何正确引用选项卡

下面的代码可以工作,但由于注释掉了这一行,所以什么也不做。我知道该行中的“self”有问题(单击按钮时,取消对该行的注释会导致错误),但我不知道应该如何使其工作。我猜我的问题在于标签是由不同的类创建的,但是我希望能够打开多个标签,每个标签中都有相同的小部件(就像这段代码所做的那样)。我是否需要重新构造代码来实现这一点

from PyQt5.QtWidgets import (QMainWindow, QApplication, QAction, qApp,
    QPushButton, QWidget, QMenu, QVBoxLayout, QTabWidget, QLineEdit,
    QLabel, QHBoxLayout)
import sys

class MainWin(QMainWindow):

    def __init__(self):
        super().__init__()

        self.initUI()

    def initUI(self):

        exitAct = QAction('&Exit', self)
        exitAct.triggered.connect(qApp.quit)

        newAct = QAction('&New Tab', self)
        newAct.triggered.connect(self.newTab)

        menubar = self.menuBar()
        fileMenu = menubar.addMenu('&File')

        fileMenu.addAction(newAct)
        fileMenu.addAction(exitAct)

        self.layout = QVBoxLayout()

        self.tabbed = QTabWidget(self)
        self.layout.addWidget(self.tabbed)
        self.setCentralWidget(self.tabbed)

        self.show()

    def newTab(self):
        self.tab1 = tabbedFrame(self.tabbed)
        self.tabbed.addTab(self.tab1, self.tab1.tabName)


class tabbedFrame(QWidget):
    def __init__(self, parent):
        super(tabbedFrame, self).__init__(parent)
        layout = QVBoxLayout()
        self.updateButton = QPushButton("Update")
        self.updateButton.clicked.connect(self.updateTab)
        layout.addWidget(QLabel("Tab Name"))
        self.nameLineEdit = QLineEdit("New Tab")
        self.tabName = self.nameLineEdit.text()
        layout.addWidget(self.nameLineEdit)
        layout.addWidget(self.updateButton)
        self.setLayout(layout)

    def updateTab(self):
        tabindex = win.tabbed.currentIndex
        #win.tabbed.setTabText(self, tabindex, self.tabName)


if __name__ == '__main__':
    app = QApplication(sys.argv)
    win = MainWin()
    sys.exit(app.exec_())

您希望更改文本,并且在尝试中使用了变量tabName,但该变量采用
QLineEdit
的初始值,在您不更新它之后,您希望如何更改文本

一种解决方案是创建一个传输新标题的信号,该标题必须更新,并且必须在通过单击的信号进行单击时发出

然后,要建立新名称,必须使用
setTabText()
方法,其中必须传递选项卡索引和新名称。为此,我们可以在连接中使用
functools.partial()

import sys
from functools import partial
from PyQt5 import QtCore, QtWidgets


class MainWin(QtWidgets.QMainWindow):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        exitAct = QtWidgets.QAction('&Exit', self)
        exitAct.triggered.connect(QtWidgets.qApp.quit)
        newAct = QtWidgets.QAction('&New Tab', self)
        newAct.triggered.connect(self.newTab)
        menubar = self.menuBar()
        fileMenu = menubar.addMenu('&File')

        fileMenu.addAction(newAct)
        fileMenu.addAction(exitAct)
        self.tabbed = QtWidgets.QTabWidget()
        self.setCentralWidget(self.tabbed)

        self.show()

    def newTab(self):
        tab = TabbedFrame()
        ix = self.tabbed.addTab(tab, "")
        tab.nameTabChanged.connect(partial(self.tabbed.setTabText, ix))
        tab.updateTab()


class TabbedFrame(QtWidgets.QWidget):
    nameTabChanged = QtCore.pyqtSignal(str)

    def __init__(self, parent=None):
        super(TabbedFrame, self).__init__(parent)

        updateButton = QtWidgets.QPushButton("Update")
        updateButton.clicked.connect(self.updateTab)
        self.nameLineEdit = QtWidgets.QLineEdit("New Tab")

        layout = QtWidgets.QVBoxLayout(self)
        layout.addWidget(QtWidgets.QLabel("Tab Name"))
        layout.addWidget(self.nameLineEdit)
        layout.addWidget(updateButton)
        layout.addStretch()

    def updateTab(self):
        new_name = self.nameLineEdit.text()
        self.nameTabChanged.emit(new_name)


if __name__ == '__main__':
    app = QtWidgets.QApplication(sys.argv)
    win = MainWin()
    sys.exit(app.exec_())