python - 从 sqlite3 填充组合框可编辑用户名和行编辑密码

标签 python python-3.x sqlite pyqt pyqt5

我有 1 个组合框可编辑用户名和 1 行编辑密码,我想将用户列表从数据库 sqlite3 加载到组合框。加载列表后,我想对项目列表组合框执行操作,从数据库中获取当前选定用户的密码。

pyqt5应用

表格列

表格记录

######Combo Box 2 - PM's
        self.groupBox_2 = QtWidgets.QGroupBox(self.tab)
        self.groupBox_2.setGeometry(QtCore.QRect(10, 140, 191, 51))
        self.groupBox_2.setObjectName("groupBox_2")
        self.comboBox_3 = QtWidgets.QComboBox(self.groupBox_2)
        self.comboBox_3.setGeometry(QtCore.QRect(10, 20, 171, 22))
        self.comboBox_3.setObjectName("comboBox_3")
        self.comboBox_3.addItems(self.pm_Combo)

def pm_Combo(self):
        conn = sqlite3.connect('testdb.db')
        c = conn.cursor()
        c.execute("SELECT DISTINCT projectmanager FROM testtable2")
        pmList = c.fetchall()
        conn.commit()
        conn.close()

最佳答案

假设该表名为“user”,那么当QComboBox的currentIndex发生变化时,可以使用userData来保存信息并在QLineEdit中设置:

import os
import sqlite3
import sys

from PyQt5 import QtWidgets, QtSql


class Widget(QtWidgets.QWidget):
    def __init__(self, parent=None):
        super().__init__(parent)

        self.username_combo = QtWidgets.QComboBox()
        self.password_lineedit = QtWidgets.QLineEdit()

        button_login = QtWidgets.QPushButton(self.tr("Login"))

        lay = QtWidgets.QFormLayout(self)
        lay.addRow(self.tr("Username:"), self.username_combo)
        lay.addRow(self.tr("Password:"), self.password_lineedit)
        lay.addRow(button_login)

        self.username_combo.currentIndexChanged.connect(self.update_password)

        self.load_usernames()

    def load_usernames(self):
        current_dir = os.path.dirname(os.path.realpath(__file__))
        db_path = os.path.join(current_dir, "testdb.db")

        self.username_combo.clear()
        with sqlite3.connect(db_path) as conn:
            cursor = conn.execute("SELECT DISTINCT username, password FROM User")
            for result in cursor.fetchall():
                username, password = result
                self.username_combo.addItem(username, password)

    def update_password(self):
        self.password_lineedit.setText(self.username_combo.currentData())


if __name__ == "__main__":
    app = QtWidgets.QApplication(sys.argv)
    w = Widget()
    w.show()
    sys.exit(app.exec_())

另一种可能的解决方案是将 QSqlQueryModel 与 QDataWidgetMapper 一起使用:

import os
import sys

from PyQt5 import QtWidgets, QtSql


def create_connection():
    current_dir = os.path.dirname(os.path.realpath(__file__))
    db_path = os.path.join(current_dir, "testdb.db")

    db = QtSql.QSqlDatabase.addDatabase("QSQLITE")
    db.setDatabaseName(db_path)
    if not db.open():
        print("error: {}".format(db.lastError().text()))
        return False
    return True


class Widget(QtWidgets.QWidget):
    def __init__(self, parent=None):
        super().__init__(parent)

        self.username_combo = QtWidgets.QComboBox()
        self.password_lineedit = QtWidgets.QLineEdit()

        button_login = QtWidgets.QPushButton(self.tr("Login"))

        lay = QtWidgets.QFormLayout(self)
        lay.addRow(self.tr("Username:"), self.username_combo)
        lay.addRow(self.tr("Password:"), self.password_lineedit)
        lay.addRow(button_login)
        self.load_data()

    def load_data(self):
        self.model = QtSql.QSqlQueryModel()
        self.model.setQuery("""SELECT DISTINCT username, password FROM User""")
        self.mapper = QtWidgets.QDataWidgetMapper()
        self.mapper.setModel(self.model)
        self.mapper.addMapping(self.password_lineedit, 1)
        self.username_combo.currentIndexChanged.connect(self.mapper.setCurrentIndex)
        self.username_combo.setModel(self.model)


if __name__ == "__main__":
    app = QtWidgets.QApplication(sys.argv)

    if not create_connection():
        sys.exit(-1)

    w = Widget()
    w.show()

    sys.exit(app.exec_())

关于python - 从 sqlite3 填充组合框可编辑用户名和行编辑密码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59386218/

相关文章:

python - 使用 Flask key 创建过程了解环境变量

python - 从文本文件导入变量并在方程中使用它

html - 如何将 django forms.py 选择项转换为 html 列表?

ios - FMDB 和加密

python - 解析的部分评估

python - 如何包装 Objective-C,以便从 Python 调用?

python pandas agg 和 count 在同一行

python-3.x - 将 .sav 文件转换为 Pandas 数据框

mysql - 如何在 Windows 上直接从 freeswitch 将通话数据记录存储在 MySQL 中?

database - Kotlin:sqlite数据库表未创建