PyQt5を使用してデータベースを使ってデータの格納や検索を行う方法は何ですか?

PyQt5を使用してデータベースへの接続やデータの保存、検索操作を行うためには、QtSqlモジュールを使用します。SQLiteデータベースを使用してデータの保存や検索を行う方法を示す簡単な例を以下に示します。

import sys
from PyQt5.QtWidgets import QApplication, QWidget, QVBoxLayout, QPushButton, QLabel, QLineEdit, QMessageBox
from PyQt5.QtSql import QSqlDatabase, QSqlQuery

class DatabaseExample(QWidget):
    def __init__(self):
        super().__init__()
        self.setWindowTitle('Database Example')
        
        layout = QVBoxLayout()
        
        self.name_label = QLabel('Name:')
        self.name_edit = QLineEdit()
        
        self.save_button = QPushButton('Save')
        self.save_button.clicked.connect(self.save_data)
        
        self.retrieve_button = QPushButton('Retrieve')
        self.retrieve_button.clicked.connect(self.retrieve_data)
        
        layout.addWidget(self.name_label)
        layout.addWidget(self.name_edit)
        layout.addWidget(self.save_button)
        layout.addWidget(self.retrieve_button)
        
        self.setLayout(layout)
        
        self.db = QSqlDatabase.addDatabase('QSQLITE')
        self.db.setDatabaseName('data.db')
        
        if not self.db.open():
            QMessageBox.critical(None, 'Error', 'Could not open database')
        
    def save_data(self):
        name = self.name_edit.text()
        
        query = QSqlQuery()
        query.prepare('INSERT INTO users (name) VALUES (?)')
        query.bindValue(0, name)
        
        if not query.exec():
            QMessageBox.critical(None, 'Error', 'Could not save data')
        else:
            QMessageBox.information(None, 'Success', 'Data saved successfully')
            
    def retrieve_data(self):
        query = QSqlQuery()
        query.prepare('SELECT name FROM users')
        
        if query.exec():
            while query.next():
                name = query.value(0)
                print(name)
        else:
            QMessageBox.critical(None, 'Error', 'Could not retrieve data')
        
if __name__ == '__main__':
    app = QApplication(sys.argv)
    window = DatabaseExample()
    window.show()
    sys.exit(app.exec_())

上記の例では、テキストボックスと2つのボタンを含む簡単なGUIアプリケーションを作成しました。ユーザーは名前を入力し、「保存」ボタンをクリックするとデータがSQLiteデータベースに保存されます。また、「検索」ボタンをクリックするとデータベースからすべてのデータを取得することもできます。

この例を実行する前に、PyQt5とsqlite3のモジュールをインストールする必要があります。これらのモジュールをインストールするには、以下のコマンドを使用できます。

pip install PyQt5
pip install pysqlite3

実際の運用では、異なる状況に適応するために必要に応じてデータベース接続情報やSQLクエリを変更することができます。

bannerAds