我需要一个程序的帮助。这是我的洞程序的一部分,我需要帮助我的组合框,我有一个组合框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_())
答案 0 :(得分:1)
如果我没弄错,你只需将它作为参数传递给你的passtt函数。但首先你需要改变你的信号:
self.comboADV.activated.connect(self.passtt) -> self.comboADV.activated[str].connect(self.passtt)
然后:
def passtt(self,item):
print(item)