Python 如何在应用程序启动时设置小部件的焦点?

Python 如何在应用程序启动时设置小部件的焦点?,python,python-2.7,pyside,setfocus,qlineedit,Python,Python 2.7,Pyside,Setfocus,Qlineedit,我试图在应用程序启动时将焦点设置在QLineEdit小部件上,但由于某些原因,它失败了。调用包含QLineEdit\u object.setFocus()并绑定到按钮单击的方法非常有效。然而,在启动时,当设置为在小部件创建后初始化时,它似乎根本不会执行 将PySide与Python结合使用 # coding=utf-8 import sys import PySide.QtGui as QG import PySide.QtCore as QC class GG(QG.QMainWindow)

我试图在应用程序启动时将焦点设置在
QLineEdit
小部件上,但由于某些原因,它失败了。调用包含
QLineEdit\u object.setFocus()
并绑定到按钮单击的方法非常有效。然而,在启动时,当设置为在小部件创建后初始化时,它似乎根本不会执行

将PySide与Python结合使用

# coding=utf-8
import sys
import PySide.QtGui as QG
import PySide.QtCore as QC

class GG(QG.QMainWindow):
    def __init__(self):
        super(GG, self).__init__()
        self.move(0,0)
        self.resize(400,300)
        self.setWindowTitle('Demo')

        self.tabw = QG.QTabWidget()
        self.tab1 = Tab1()
        self.tab2 = Tab2()

        self.tabw.addTab(self.tab1, 'Tab1')
        self.tabw.addTab(self.tab2, 'Tab2')

        hbox = QG.QHBoxLayout()
        hbox.addWidget(self.tabw)

        self.setCentralWidget(self.tabw)
        self.setLayout(hbox)
        self.show()

class Tab1(QG.QWidget):
    def __init__(self):
        super(Tab1, self).__init__()

        self.btns()
        self.inputt()
        self.layoutz()
        self.inp.setFocus() # doesn't set the focus on startup ?
        self.show()

    def inputt(self):
        self.inp = QG.QLineEdit('', self)

    def btns(self):
        self.btn1 = QG.QPushButton('Button1', self)
        self.btn1.clicked.connect(self.focusit) # works just fine

    def layoutz(self):
        vbox = QG.QVBoxLayout()   
        vbox.addWidget(self.btn1)
        vbox.addStretch(1)
        vbox.addWidget(self.inp)
        self.setLayout(vbox)

    def focusit(self):
        self.inp.setFocus() # works just fine


class Tab2(Tab1):
    def __init__(self):
        super(Tab2, self).__init__()


def main():
    app = QG.QApplication(sys.argv)
    a = GG()
    sys.exit(app.exec_())

if __name__ == '__main__':
   main()

好吧,在玩了一番之后,我想出了这个解决方案:

import sys
import PySide.QtGui as QG
import PySide.QtCore as QC

class GG(QG.QMainWindow):
    def __init__(self):
        super(GG, self).__init__()
        self.move(0,0)
        self.resize(400,300)
        self.setWindowTitle('Demo')

        self.tabw = QG.QTabWidget()
        self.tab1 = Tab1()
        self.tab2 = Tab2()

        self.tabw.addTab(self.tab1, 'Tab1')
        self.tabw.addTab(self.tab2, 'Tab2')

        hbox = QG.QHBoxLayout()
        hbox.addWidget(self.tabw)

        self.setCentralWidget(self.tabw)
        self.setLayout(hbox)
        self.tab2.inp.setFocus() # setting focus right here
        self.tab1.inp.setFocus() # and here; notice the order
        self.show()

class Tab1(QG.QWidget):
    def __init__(self):
        super(Tab1, self).__init__()

        self.btns()
        self.inputt()
        self.layoutz()
        self.show()

    def inputt(self):
        self.inp = QG.QLineEdit('', self)

    def btns(self):
        self.btn1 = QG.QPushButton('Button1', self)
        self.btn1.clicked.connect(self.focusit)

    def layoutz(self):
        vbox = QG.QVBoxLayout()   
        vbox.addWidget(self.btn1)
        vbox.addStretch(1)
        vbox.addWidget(self.inp)
        self.setLayout(vbox)

    def focusit(self):
        self.inp.setFocus()


class Tab2(Tab1):
    def __init__(self):
        super(Tab2, self).__init__()


def main():
    app = QG.QApplication(sys.argv)
    a = GG()
    sys.exit(app.exec_())

if __name__ == '__main__':
   main()

对我来说很好。请提供一个小的、自包含的示例,演示您遇到的问题。如下所示: