


Création d'un gestionnaire de bibliothèque SQLite simple en Python
Création d'un gestionnaire de bibliothèque SQLite simple en Python
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 :
- Créez une base de données et une table SQLite.
- Insérez des enregistrements tout en évitant les doublons.
- Récupérez des données en fonction de critères spécifiques.
1. Création de la base de données et de la table
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.
- Insérer des livres dans la base de données
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.
3. Ajouter quelques livres
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.
4. Récupérer des livres
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)
Conclusion
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 :
- Recherche de livres par titre ou auteur.
- Mise à jour des informations sur le livre.
- Supprimer des livres.
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Solution aux problèmes d'autorisation Lors de la visualisation de la version Python dans Linux Terminal Lorsque vous essayez d'afficher la version Python dans Linux Terminal, entrez Python ...

Comment éviter d'être détecté lors de l'utilisation de FiddlereVerywhere pour les lectures d'homme dans le milieu lorsque vous utilisez FiddlereVerywhere ...

Lorsque vous utilisez la bibliothèque Pandas de Python, comment copier des colonnes entières entre deux frames de données avec différentes structures est un problème courant. Supposons que nous ayons deux dats ...

Comment enseigner les bases de la programmation novice en informatique dans les 10 heures? Si vous n'avez que 10 heures pour enseigner à l'informatique novice des connaissances en programmation, que choisissez-vous d'enseigner ...

Comment Uvicorn écoute-t-il en permanence les demandes HTTP? Uvicorn est un serveur Web léger basé sur ASGI. L'une de ses fonctions principales est d'écouter les demandes HTTP et de procéder ...

Fastapi ...

Utilisation de Python dans Linux Terminal ...

Comprendre la stratégie anti-rampe d'investissement.com, Beaucoup de gens essaient souvent de ramper les données d'actualités sur Investing.com (https://cn.investing.com/news/latest-news) ...
