


Erstellen eines einfachen SQLite-Bibliotheksmanagers in Python
Erstellen eines einfachen SQLite-Bibliotheksmanagers in Python
Die effiziente Verwaltung von Daten ist ein wichtiger Bestandteil jedes Projekts, und SQLite macht diese Aufgabe einfach und unkompliziert. In diesem Tutorial erstellen wir eine kleine Python-Anwendung zum Verwalten einer Bibliotheksdatenbank, die es Ihnen ermöglicht, Bücher mit minimalem Aufwand hinzuzufügen und abzurufen.
Am Ende dieses Artikels wissen Sie, wie Sie:
- Erstellen Sie eine SQLite-Datenbank und -Tabelle.
- Fügen Sie Datensätze ein und vermeiden Sie gleichzeitig Duplikate.
- Daten basierend auf bestimmten Kriterien abrufen.
1. Erstellen der Datenbank und Tabelle
Beginnen wir mit der Erstellung unserer SQLite-Datenbankdatei und der Definition der Büchertabelle. Jedes Buch verfügt über Felder für Titel, Autor, ISBN, Veröffentlichungsdatum und 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}")
Führen Sie diese Funktion aus, um die Datenbank zu initialisieren:
create_library_database()
Dadurch wird in Ihrem Projektverzeichnis eine Datei „library.db“ erstellt, die eine Büchertabelle mit den angegebenen Feldern enthält.
- Bücher in die Datenbank einfügen
Beim Einfügen von Büchern möchten wir sicherstellen, dass doppelte Einträge (basierend auf dem isbn-Feld) vermieden werden. Anstatt manuell nach Duplikaten zu suchen, verwenden wir die INSERT OR IGNORE-Anweisung von SQLite.
Hier ist die Funktion zum Hinzufügen von Büchern:
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()
Diese Funktion verwendet die SQL-Anweisung INSERT OR IGNORE, um sicherzustellen, dass doppelte Einträge effizient übersprungen werden.
3. Einige Bücher hinzufügen
Testen wir die Funktion insert_book, indem wir einige Bücher zu unserer Bibliothek hinzufügen.
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)
Wenn Sie den obigen Code ausführen, werden die Bücher zur Datenbank hinzugefügt. Wenn Sie es erneut ausführen, sehen Sie Meldungen wie:
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. Bücher abrufen
Sie können Daten einfach durch Abfragen der Datenbank abrufen. Um beispielsweise alle Bücher in der Bibliothek abzurufen:
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)
Abschluss
Mit nur wenigen Zeilen Python verfügen Sie jetzt über einen funktionsfähigen Bibliotheksmanager, der Bücher einfügen, Duplikate verhindern und Datensätze mühelos abrufen kann. INSERT OR IGNORE von SQLite ist eine leistungsstarke Funktion, die die Handhabung von Einschränkungen vereinfacht und Ihren Code prägnanter und effizienter macht.
Erweitern Sie dieses Projekt gerne mit Funktionen wie:
- Suche nach Büchern nach Titel oder Autor.
- Buchinformationen werden aktualisiert.
- Bücher löschen.
Was wirst du als nächstes bauen? ?
Das obige ist der detaillierte Inhalt vonErstellen eines einfachen SQLite-Bibliotheksmanagers in Python. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen











Python zeichnet sich in Gaming und GUI -Entwicklung aus. 1) Spielentwicklung verwendet Pygame, die Zeichnungen, Audio- und andere Funktionen bereitstellt, die für die Erstellung von 2D -Spielen geeignet sind. 2) Die GUI -Entwicklung kann Tkinter oder Pyqt auswählen. Tkinter ist einfach und einfach zu bedienen. PYQT hat reichhaltige Funktionen und ist für die berufliche Entwicklung geeignet.

Python ist leichter zu lernen und zu verwenden, während C leistungsfähiger, aber komplexer ist. 1. Python -Syntax ist prägnant und für Anfänger geeignet. Durch die dynamische Tippen und die automatische Speicherverwaltung können Sie die Verwendung einfach zu verwenden, kann jedoch zur Laufzeitfehler führen. 2.C bietet Steuerung und erweiterte Funktionen auf niedrigem Niveau, geeignet für Hochleistungsanwendungen, hat jedoch einen hohen Lernschwellenwert und erfordert manuellem Speicher und Typensicherheitsmanagement.

Um die Effizienz des Lernens von Python in einer begrenzten Zeit zu maximieren, können Sie Pythons DateTime-, Zeit- und Zeitplanmodule verwenden. 1. Das DateTime -Modul wird verwendet, um die Lernzeit aufzuzeichnen und zu planen. 2. Das Zeitmodul hilft, die Studie zu setzen und Zeit zu ruhen. 3. Das Zeitplanmodul arrangiert automatisch wöchentliche Lernaufgaben.

Python ist in der Entwicklungseffizienz besser als C, aber C ist in der Ausführungsleistung höher. 1. Pythons prägnante Syntax und reiche Bibliotheken verbessern die Entwicklungseffizienz. 2. Die Kompilierungsmerkmale von Compilation und die Hardwarekontrolle verbessern die Ausführungsleistung. Bei einer Auswahl müssen Sie die Entwicklungsgeschwindigkeit und die Ausführungseffizienz basierend auf den Projektanforderungen abwägen.

PythonlistsarePartThestandardlibrary, whilearraysarenot.listarebuilt-in, vielseitig und UNDUSEDFORSPORINGECollections, während dieArrayRay-thearrayModulei und loses und loses und losesaluseduetolimitedFunctionality.

Ist es genug, um Python für zwei Stunden am Tag zu lernen? Es hängt von Ihren Zielen und Lernmethoden ab. 1) Entwickeln Sie einen klaren Lernplan, 2) Wählen Sie geeignete Lernressourcen und -methoden aus, 3) praktizieren und prüfen und konsolidieren Sie praktische Praxis und Überprüfung und konsolidieren Sie und Sie können die Grundkenntnisse und die erweiterten Funktionen von Python während dieser Zeit nach und nach beherrschen.

Python zeichnet sich in Automatisierung, Skript und Aufgabenverwaltung aus. 1) Automatisierung: Die Sicherungssicherung wird durch Standardbibliotheken wie OS und Shutil realisiert. 2) Skriptschreiben: Verwenden Sie die PSUTIL -Bibliothek, um die Systemressourcen zu überwachen. 3) Aufgabenverwaltung: Verwenden Sie die Zeitplanbibliothek, um Aufgaben zu planen. Die Benutzerfreundlichkeit von Python und die Unterstützung der reichhaltigen Bibliothek machen es zum bevorzugten Werkzeug in diesen Bereichen.

Python und C haben jeweils ihre eigenen Vorteile, und die Wahl sollte auf Projektanforderungen beruhen. 1) Python ist aufgrund seiner prägnanten Syntax und der dynamischen Typisierung für die schnelle Entwicklung und Datenverarbeitung geeignet. 2) C ist aufgrund seiner statischen Tipp- und manuellen Speicherverwaltung für hohe Leistung und Systemprogrammierung geeignet.
