從sqlite中選擇表名以顯示在組合框tabSelection中時,Combobox dbSelection不會更新以應用於代碼中。PyQt4 Combobox在初始選擇後未更新
單擊按鈕後,加載目錄對話窗口也需要很長時間。
我還想確保數據庫中的所有表都列在tabSelection組合框中。
的代碼如下,與Qt設計文件相關聯:
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_()
如果您正在使用PyQt4的我建議使用QtSql模塊,例如,如果您使用一個QSqlTableModel的QTableView中,它會自動而不需要編寫SQL請求加載。 – eyllanesc