Заполнение комбобокса из базы данных SQLite в PyQt ⇐ Python
Заполнение комбобокса из базы данных SQLite в PyQt
Я пытаюсь заполнить комбобокс из базы данных SQLite, но ничего не получается.
Мой код
импортировать систему из PyQt6 импортировать QtWidgets из PyQt6.QtSql импортировать QSqlTableModel импортировать sqlite3 из test_rt_sql импорта Ui_MainWindow класс MainWindow(QtWidgets.QMainWindow, Ui_MainWindow): защита __init__(сам): супер().__init__() self.ui = Ui_MainWindow() self.ui.setupUi(сам) self.model = QSqlTableModel() self.model.setTable('пользователь') self.model.select() self.ui.comboBox.setModel(self.model) self.ui.comboBox.currentIndexChanged.connect(self.comboBox_val) себя.шоу() защита comboBox_val (сам): conn = sqlite3.connect('C:/sqlite/test.db') с = конн.курсор() c.execute('ВЫБРАТЬ имя ОТ пользователя') строки = c.fetchall() для строки в строках: self.ui.comboBox.addItems(строка) конн.закрыть() если __name__ == "__main__": приложение = QtWidgets.QApplication(sys.argv) окно = ГлавноеОкно() sys.exit(app.exec()) Я пытался вернуть ему список в addItems, получил ошибку
self.ui.comboBox.addItems(self.comboBox_val) TypeError: addItems(self, texts: Iterable[Optional[str]]): аргумент 1 имеет неожиданный тип «метод» Насколько я понимаю, ему не нравится аргумент addItems, который там конкретно относится не к данным, а к методу.
Код, в который был возвращен список:
из PyQt6 импортировать QtWidgets из PyQt6.QtSql импортировать QSqlTableModel импортировать sqlite3 из test_rt_sql импорта Ui_MainWindow класс MainWindow(QtWidgets.QMainWindow, Ui_MainWindow): защита __init__(сам): супер().__init__() self.ui = Ui_MainWindow() self.ui.setupUi(сам) self.model = QSqlTableModel() self.model.setTable('пользователь') self.model.select() self.ui.comboBox.setModel(self.model) self.ui.comboBox.addItems(self.comboBox_val) себя.шоу() защита comboBox_val (сам): глобальные данные1 conn = sqlite3.connect('C:/sqlite/test.db') с = конн.курсор() c.execute('ВЫБРАТЬ имя ОТ пользователя') данные1 = [] для строки в c.fetchall(): data1.append(str(строка)) вернуть данные1 если __name__ == "__main__": приложение = QtWidgets.QApplication(sys.argv) окно = ГлавноеОкно() sys.exit(app.exec() База данных точно подключена и данные предоставлены. Я проверил это вот так.
импортировать sqlite3 защита comboBox_val(): conn = sqlite3.connect('C:/sqlite/test.db') с = конн.курсор() c.execute('ВЫБРАТЬ имя ОТ пользователя') строки = c.fetchall() для строки в строках: печать (строка) комбоБокс_val() введите здесь описание изображения
Я пытаюсь заполнить комбобокс из базы данных SQLite, но ничего не получается.
Мой код
импортировать систему из PyQt6 импортировать QtWidgets из PyQt6.QtSql импортировать QSqlTableModel импортировать sqlite3 из test_rt_sql импорта Ui_MainWindow класс MainWindow(QtWidgets.QMainWindow, Ui_MainWindow): защита __init__(сам): супер().__init__() self.ui = Ui_MainWindow() self.ui.setupUi(сам) self.model = QSqlTableModel() self.model.setTable('пользователь') self.model.select() self.ui.comboBox.setModel(self.model) self.ui.comboBox.currentIndexChanged.connect(self.comboBox_val) себя.шоу() защита comboBox_val (сам): conn = sqlite3.connect('C:/sqlite/test.db') с = конн.курсор() c.execute('ВЫБРАТЬ имя ОТ пользователя') строки = c.fetchall() для строки в строках: self.ui.comboBox.addItems(строка) конн.закрыть() если __name__ == "__main__": приложение = QtWidgets.QApplication(sys.argv) окно = ГлавноеОкно() sys.exit(app.exec()) Я пытался вернуть ему список в addItems, получил ошибку
self.ui.comboBox.addItems(self.comboBox_val) TypeError: addItems(self, texts: Iterable[Optional[str]]): аргумент 1 имеет неожиданный тип «метод» Насколько я понимаю, ему не нравится аргумент addItems, который там конкретно относится не к данным, а к методу.
Код, в который был возвращен список:
из PyQt6 импортировать QtWidgets из PyQt6.QtSql импортировать QSqlTableModel импортировать sqlite3 из test_rt_sql импорта Ui_MainWindow класс MainWindow(QtWidgets.QMainWindow, Ui_MainWindow): защита __init__(сам): супер().__init__() self.ui = Ui_MainWindow() self.ui.setupUi(сам) self.model = QSqlTableModel() self.model.setTable('пользователь') self.model.select() self.ui.comboBox.setModel(self.model) self.ui.comboBox.addItems(self.comboBox_val) себя.шоу() защита comboBox_val (сам): глобальные данные1 conn = sqlite3.connect('C:/sqlite/test.db') с = конн.курсор() c.execute('ВЫБРАТЬ имя ОТ пользователя') данные1 = [] для строки в c.fetchall(): data1.append(str(строка)) вернуть данные1 если __name__ == "__main__": приложение = QtWidgets.QApplication(sys.argv) окно = ГлавноеОкно() sys.exit(app.exec() База данных точно подключена и данные предоставлены. Я проверил это вот так.
импортировать sqlite3 защита comboBox_val(): conn = sqlite3.connect('C:/sqlite/test.db') с = конн.курсор() c.execute('ВЫБРАТЬ имя ОТ пользователя') строки = c.fetchall() для строки в строках: печать (строка) комбоБокс_val() введите здесь описание изображения
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Ошибка базы данных SQLite студии Android (android.database.sqlite.SQLiteException)
Anonymous » » в форуме Android - 0 Ответы
- 59 Просмотры
-
Последнее сообщение Anonymous
-