Pyqt - Combobox,如何返回所选文本

时间:2013-08-12 18:07:38

标签: python qt combobox pyqt

我需要一个程序的帮助。这是我的洞程序的一部分,我需要帮助我的组合框,我有一个组合框ADV,这个组合的数据来自我的数据库...... 我需要在组合框上获取所选项目并将其作为变量传递,因为在我创建一个tablewidget并使用名称作为参数插入db的内容以从我的表中获取“东西”...示例:i在这个组合中选择“rororo”..所以选中..然后将其作为变量传递并在我的数据库中搜索此变量。我知道如何进行搜索,但我不知道如何将其作为变量传递..我的变量在我的“pass_t”def ..但我想将它返回到我的setupUI def来进行搜索.. < / p>

from PyQt4.QtGui import * 
from PyQt4.QtSql import * 
from PyQt4.QtCore import * 
import sys

try:
  _fromUtf8 = QString.fromUtf8
except AttributeError:
  _fromUtf8 = lambda s: s

class Ui_MainWindow(object):

  def setupUi(self, MainWindow):
      MainWindow.setObjectName(_fromUtf8("MainWindow"))
      MainWindow.resize(800, 600)
      self.centralwidget = QWidget(MainWindow)
      self.centralwidget.setObjectName(_fromUtf8("centralwidget"))
      self.comboADV = QComboBox(self.centralwidget)
      self.comboADV.setGeometry(QRect(110, 80, 91, 31))
      self.comboADV.setObjectName(_fromUtf8("comboADV"))
      self.comboADV.addItem(_fromUtf8(""))
      db = QSqlDatabase.addDatabase("QMYSQL")
      db.setHostName('localhost')
      db.setDatabaseName('database')
      db.setUserName('username')
      db.setPassword('password')
      if (db.open()==False):     

        QMessageBox.critical(None, "Database Error",
            db.lastError().text())   
      query  = QSqlQuery ("SELECT Palavra FROM Tabela053 WHERE Categoria='Adv.' ORDER BY Palavra ASC;")
      index=0
      while (query.next()):
      self.comboADV.addItem(query.value(0).toString())
      index = index+1
      self.comboADV.activated.connect(self.passtt) #want to change this
#---------------------------------------important
  def passtt(self):
      a = self.comboADV.currentText()
      print a #here i can print the selected content of my comboADV
if __name__ == "__main__":
  import sys

  app = QApplication(sys.argv)
  MainWindow = QMainWindow()

  ui = Ui_MainWindow()
  ui.setupUi(MainWindow)

MainWindow.show()
sys.exit(app.exec_())

1 个答案:

答案 0 :(得分:1)

如果我没弄错,你只需将它作为参数传递给你的passtt函数。但首先你需要改变你的信号:

self.comboADV.activated.connect(self.passtt) -> self.comboADV.activated[str].connect(self.passtt)

然后:

def passtt(self,item):
    print(item)