ホームページ >バックエンド開発 >Python チュートリアル >Python での単純な SQLite ライブラリ マネージャーの構築
データを効率的に管理することは、あらゆるプロジェクトの重要な部分であり、SQLite を使用すると、このタスクがシンプルかつ軽量になります。このチュートリアルでは、最小限の労力で本の追加と取得を可能にする、図書館データベースを管理するための小さな Python アプリケーションを構築します。
この記事を読み終えるまでに、次の方法がわかるようになります。
SQLite データベース ファイルを作成し、books テーブルを定義することから始めましょう。各書籍には、タイトル、著者、ISBN、発行日、およびジャンルのフィールドがあります。
import sqlite3 import os def create_library_database(): """Creates the library database if it doesn't already exist.""" db_name = "library.db" if not os.path.exists(db_name): print(f"Creating database: {db_name}") conn = sqlite3.connect(db_name) cursor = conn.cursor() cursor.execute(''' CREATE TABLE IF NOT EXISTS books ( id INTEGER PRIMARY KEY AUTOINCREMENT, title TEXT, author TEXT, isbn TEXT UNIQUE, published_date DATE, genre TEXT ) ''') conn.commit() conn.close() else: print(f"Database already exists: {db_name}")
この関数を実行してデータベースを初期化します:
create_library_database()
これにより、プロジェクト ディレクトリに library.db ファイルが作成され、指定されたフィールドを持つ書籍テーブルが含まれます。
書籍を挿入するには、(isbn フィールドに基づいて) 重複したエントリを確実に回避する必要があります。手動で重複をチェックする代わりに、SQLite の INSERT OR IGNORE ステートメントを使用します。
書籍を追加する機能は次のとおりです:
def insert_book(book): """ Inserts a book into the database. If a book with the same ISBN already exists, the insertion is ignored. """ conn = sqlite3.connect("library.db") cursor = conn.cursor() try: # Insert the book. Ignore the insertion if the ISBN already exists. cursor.execute(''' INSERT OR IGNORE INTO books (title, author, isbn, published_date, genre) VALUES (?, ?, ?, ?, ?) ''', (book["title"], book["author"], book["isbn"], book["published_date"], book["genre"])) conn.commit() if cursor.rowcount == 0: print(f"The book with ISBN '{book['isbn']}' already exists in the database.") else: print(f"Book inserted: {book['title']} by {book['author']}") except sqlite3.Error as e: print(f"Database error: {e}") finally: conn.close()
この関数は INSERT OR IGNORE SQL ステートメントを使用して、重複エントリが効率的にスキップされるようにします。
ライブラリに書籍を追加して、insert_book 関数をテストしてみましょう。
books = [ { "title": "To Kill a Mockingbird", "author": "Harper Lee", "isbn": "9780061120084", "published_date": "1960-07-11", "genre": "Fiction" }, { "title": "1984", "author": "George Orwell", "isbn": "9780451524935", "published_date": "1949-06-08", "genre": "Dystopian" }, { "title": "Pride and Prejudice", "author": "Jane Austen", "isbn": "9781503290563", "published_date": "1813-01-28", "genre": "Romance" } ] for book in books: insert_book(book)
上記のコードを実行すると、書籍がデータベースに追加されます。再度実行すると、次のようなメッセージが表示されます:
The book with ISBN '9780061120084' already exists in the database. The book with ISBN '9780451524935' already exists in the database. The book with ISBN '9781503290563' already exists in the database.
データベースにクエリを実行することで、データを簡単に取得できます。たとえば、図書館内のすべての本を取得するには:
def fetch_all_books(): conn = sqlite3.connect("library.db") cursor = conn.cursor() cursor.execute("SELECT * FROM books") rows = cursor.fetchall() conn.close() return rows books = fetch_all_books() for book in books: print(book)
わずか数行の Python で、重複を防ぎながら書籍を挿入し、レコードを簡単に取得できる機能的なライブラリ マネージャーが完成しました。 SQLite の INSERT OR IGNORE は、制約の処理を簡素化し、コードをより簡潔かつ効率的にする強力な機能です。
次のような機能を使用してこのプロジェクトを自由に拡張してください:
次は何を作りますか? ?
以上がPython での単純な SQLite ライブラリ マネージャーの構築の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。