Python PyQT动态更改QMainWindow标题

Python PyQT动态更改QMainWindow标题,python,user-interface,pyqt,titlebar,Python,User Interface,Pyqt,Titlebar,我制作了一个非常简单的python脚本,将sqlite3数据库读入QtTableWidget import sqlite3 as db from PyQt4 import QtCore, QtGui import sys con = db.connect('results.db', isolation_level=None) cur = con.cursor() cur.execute("SELECT * FROM Results") all_data = cur.fetchall() c

我制作了一个非常简单的python脚本,将sqlite3数据库读入QtTableWidget

import sqlite3 as db
from PyQt4 import QtCore, QtGui
import sys

con = db.connect('results.db', isolation_level=None)
cur = con.cursor()
cur.execute("SELECT * FROM Results")
all_data = cur.fetchall()


class UiDialog(object):
    def setupUi(self, datadb):
        datadb.setObjectName("Dialog")
        datadb.resize(404, 304)
        datadb.setWindowTitle("Database results")
        sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Fixed, QtGui.QSizePolicy.Fixed)
        sizePolicy.setHorizontalStretch(0)
        sizePolicy.setVerticalStretch(0)
        sizePolicy.setHeightForWidth(datadb.sizePolicy().hasHeightForWidth())
        datadb.setSizePolicy(sizePolicy)
        datadb.setMinimumSize(QtCore.QSize(404, 304))
        datadb.setMaximumSize(QtCore.QSize(404, 304))
        self.table = QtGui.QTableWidget(datadb)
        self.table.setGeometry(QtCore.QRect(2, 2, 400, 261))
        self.table.setObjectName("table")
        self.show = QtGui.QPushButton(datadb)
        self.show.setGeometry(QtCore.QRect(2, 270, 400, 31))
        self.show.setObjectName("show")
        self.show.setText("Show results")
        QtCore.QObject.connect(self.show, QtCore.SIGNAL("clicked()"), self.populate)
        QtCore.QMetaObject.connectSlotsByName(datadb)

    def populate(self):
        self.table.setRowCount(len(all_data))
        self.table.setColumnCount(4)
        self.table.setHorizontalHeaderLabels(['Number', 'Keys', 'Time', 'Tries'])
        for i, item in enumerate(all_data):
            number = QtGui.QTableWidgetItem(str(item[0]))
            keys = QtGui.QTableWidgetItem(item[1])
            time = QtGui.QTableWidgetItem(str(item[2]))
            tries = QtGui.QTableWidgetItem(str(item[3]))
            self.table.setItem(i, 0, number)
            self.table.setItem(i, 1, keys)
            self.table.setItem(i, 2, time)
            self.table.setItem(i, 3, tries)

if __name__ == "__main__":
    app = QtGui.QApplication(sys.argv)
    main_conf = QtGui.QDialog()
    ui = UiDialog()
    ui.setupUi(main_conf)
    main_conf.show()
    ret = app.exec_()
    sys.exit(ret)
它很好用。我现在的问题是:

有没有办法在运行时动态更改窗口标题?

setWindowTitle()不会动态更新标题栏,也不会更新()或重新绘制()

非常感谢您宝贵的时间

def setupUi(self, datadb):
    [...]
    self.datadb = datadb

def populate(self):
    [...]
    self.datadb.setWindowTitle('new title')
这很有效。但是您正在以一种奇怪而不方便的方式构建小部件。更传统的方法是使用继承:

class DatabaseUi(QtGui.QDialog):
    def __init__(self):
        QtGui.QDialog.__init__(self)

        self.table = QtGui.QTableWidget()

        self.button = QtGui.QPushButton()
        self.button.setText("Show results")
        self.button.clicked.connect(self.populate)

        vlay = QtGui.QVBoxLayout()
        vlay.addWidget(self.table)
        vlay.addWidget(self.button)

        self.setLayout(vlay)
        self.setFixedSize(404, 304)
        self.setWindowTitle("Database results")

    def populate(self):
        self.setWindowTitle('new title')
        self.table.setColumnCount(4)
        self.table.setHorizontalHeaderLabels(['Number', 'Keys', 'Time', 'Tries'])
        [...]


if __name__ == "__main__":
    app = QtGui.QApplication(sys.argv)

    ui = DatabaseUi()
    ui.show()

    sys.exit(app.exec_())
另一个解决方案:

class UiDialog(object):
    def setupUi(self, datadb):
        datadb.setObjectName("Dialog")
        datadb.resize(404, 304)
        datadb.setWindowTitle("Database results")
        sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Fixed, QtGui.QSizePolicy.Fixed)
        sizePolicy.setHorizontalStretch(0)
        sizePolicy.setVerticalStretch(0)
        sizePolicy.setHeightForWidth(datadb.sizePolicy().hasHeightForWidth())
        datadb.setSizePolicy(sizePolicy)
        datadb.setMinimumSize(QtCore.QSize(404, 304))
        datadb.setMaximumSize(QtCore.QSize(404, 304))
        self.table = QtGui.QTableWidget(datadb)
        self.table.setGeometry(QtCore.QRect(2, 2, 400, 261))
        self.table.setObjectName("table")
        self.show = QtGui.QPushButton(datadb)
        self.show.setGeometry(QtCore.QRect(2, 270, 400, 31))
        self.show.setObjectName("show")
        self.show.setText("Show results")
        QtCore.QObject.connect(self.show, QtCore.SIGNAL("clicked()"), lambda: self.populate(datadb)) ### Using LAMBDA function to pass datadb object to the method
        #self.show.pressed.connect(lambda: self.populate(datadb)) ### Another syntax for the same operation
        QtCore.QMetaObject.connectSlotsByName(datadb)

    def populate(self, mainWindow):
        self.table.setRowCount(len(all_data))
        self.table.setColumnCount(4)
        self.table.setHorizontalHeaderLabels(['Number', 'Keys', 'Time', 'Tries'])
        for i, item in enumerate(all_data):
            number = QtGui.QTableWidgetItem(str(item[0]))
            keys = QtGui.QTableWidgetItem(item[1])
            time = QtGui.QTableWidgetItem(str(item[2]))
            tries = QtGui.QTableWidgetItem(str(item[3]))
            self.table.setItem(i, 0, number)
            self.table.setItem(i, 1, keys)
            self.table.setItem(i, 2, time)
            self.table.setItem(i, 3, tries)
        mainWindow.setWindowTitle("ANOTHER TITLE")
如果您使用的是从
.ui
文件生成的代码,您可以将主代码写入另一个文件,只需将生成的ui文件导入主代码,因此将来的更改不会影响或更改主代码。。。因此,我选择的最佳解决方案是:

from PyQt4 import QtCore, QtGui
from pyUI import UiDialog ### your UI file, pyUI is the file name and UiDialog is the Ui Class name
import sys

class GUI(QtGui.QDialog):

    def __init__(self):
        QtGui.QDialog.__init__(self)
        self.ui = UiDialog()
        self.ui.setupUi(self)
        self.ui.show.pressed.connect(self.populate)

    def populate(self):
        self.ui.table.setRowCount(len(all_data))
        self.ui.table.setColumnCount(4)
        self.ui.table.setHorizontalHeaderLabels(['Number', 'Keys', 'Time', 'Tries'])
        for i, item in enumerate(all_data):
            number = QtGui.QTableWidgetItem(str(item[0]))
            keys =   QtGui.QTableWidgetItem(item[1])
            time =   QtGui.QTableWidgetItem(str(item[2]))
            tries =  QtGui.QTableWidgetItem(str(item[3]))
            self.ui.table.setItem(i, 0, number)
            self.ui.table.setItem(i, 1, keys)
            self.ui.table.setItem(i, 2, time)
            self.ui.table.setItem(i, 3, tries)
        self.setWindowTitle("ANOTHER TITLE")

con = db.connect('results.db', isolation_level=None)
cur = con.cursor()
cur.execute("SELECT * FROM Results")
all_data = cur.fetchall()

app = QtGui.QApplication(sys.argv)
dailog = GUI()
dailog.show()
sys.exit(app.exec_())

self.ui.btn\u close.clicked.connect(self.btn\u close\u clicked)

def btn_关闭_单击(自行):
self.close()

OP使用的方法是中建议的方法之一。呈现的Python代码是从QT Designer ui文件自动生成的。因此,不建议像您所做的那样重构代码,因为每次修改ui文件和重新生成Python代码时都必须这样做。最好在不删除/更改
setupUi()
方法的情况下提供一个避免问题的解决方案。三个菠萝是正确的。这是从Qt Designer ui文件自动生成的代码。还有其他建议吗?除了更改
QtCore.QObject.connect(self.show,QtCore.SIGNAL(“clicked()”,self.populate)
语法外,找不到任何解决方案,如果可以更改一点,我可以发布它…是的,请发布您的解决方案。谢谢,在调用
self.ui.setupUi()之后编写
self.setWindowTitle()
成功了:)你提出的答案与问题无关。