La gestion efficace des données est un élément clé de tout projet, et SQLite rend cette tâche simple et légère. Dans ce didacticiel, nous allons créer une petite application Python pour gérer une base de données de bibliothèque, vous permettant d'ajouter et de récupérer des livres avec un minimum d'effort.
À la fin de cet article, vous saurez comment :
Commençons par créer notre fichier de base de données SQLite et définir la table books. Chaque livre aura des champs pour son titre, son auteur, son ISBN, sa date de publication et son genre.
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}")
Exécutez cette fonction pour initialiser la base de données :
create_library_database()
Cela créera un fichier library.db dans le répertoire de votre projet, contenant une table books avec les champs spécifiés.
Pour insérer des livres, nous voulons nous assurer que les entrées en double (basées sur le champ isbn) sont évitées. Au lieu de rechercher manuellement les doublons, nous utiliserons l’instruction INSERT OR IGNORE de SQLite.
Voici la fonction pour ajouter des livres :
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()
Cette fonction utilise l'instruction SQL INSERT OR IGNORE pour garantir que les entrées en double sont ignorées efficacement.
Testons la fonction insert_book en ajoutant quelques livres à notre bibliothèque.
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)
Lorsque vous exécutez le code ci-dessus, les livres seront ajoutés à la base de données. Si vous l'exécutez à nouveau, vous verrez des messages tels que :
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.
Vous pouvez facilement récupérer des données en interrogeant la base de données. Par exemple, pour récupérer tous les livres de la bibliothèque :
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)
Avec seulement quelques lignes de Python, vous disposez désormais d'un gestionnaire de bibliothèque fonctionnel capable d'insérer des livres tout en évitant les doublons et de récupérer des enregistrements sans effort. INSERT OR IGNORE de SQLite est une fonctionnalité puissante qui simplifie la gestion des contraintes, rendant votre code plus concis et efficace.
N'hésitez pas à étendre ce projet avec des fonctionnalités telles que :
Qu'allez-vous construire ensuite ? ?
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!