[英]PyQt4 Combobox Not Updating After Initial Selection
从sqlite选择表名称以显示在组合框tabSelection中时,组合框dbSelection不会更新以应用到代码中。
一旦单击按钮,加载目录对话框窗口也将花费大量时间。
我还想确保在tabSelection组合框中列出数据库中的所有表。
代码如下,并与Qt Designer文件关联:
from PyQt4.QtCore import *
from PyQt4.QtGui import *
import sys
import qcDbWidget2
import os
import sqlite3
class MainDialog(QWidget, qcDbWidget2.Ui_qcQueryWidget):
def __init__(self, parent=None):
super(MainDialog, self).__init__(parent)
self.setupUi(self)
self.connect(self.dbDirSelect, SIGNAL("clicked()"), self.getDirName)
def getDirName(self):
existDir = QFileDialog.getExistingDirectory(self)
dbDir = str(existDir)
self.dbDirDisplay.setText(dbDir)
dbFileList = []
for root, dirs, files in os.walk(dbDir):
for file in files:
if file.endswith('.db'):
dbFileList.append(file)
self.dbSelection.addItems(dbFileList)
tableList = []
self.dbSelection.update()
dbName = str(self.dbSelection.currentText())
dbPath = str(dbDir + '\\' + dbName)
conn = sqlite3.connect(dbPath)
c = conn.cursor()
res = c.execute("SELECT name FROM sqlite_master WHERE type='table';")
self.tabSelection.clear()
for name in res:
tableList.append(name[0])
print(name[0])
for name in tableList:
self.tabSelection.addItems(tableList)
app = QApplication(sys.argv)
form = MainDialog()
form.show()
app.exec_()
您是否考虑过使用QTableView代替QTableList
?
Qt使用MVC的方法比手工完成要快得多。
在这种情况下,这非常简单。
您创建一个模型:
my_model = QStringListModel()
然后,您可以将数据保存到my_model
:
my_list = ["toto", "tutu", "tata"]
my_model.setStringList(my_list)
一旦有了QTableView
,就可以使用它的setModel()方法来提供模型。
my_table_view.setModel(my_model)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.