Erstellen von KI-basierten Zusammenfassungen in einer Django-Website
Das Zusammenfassen langer Texte kann mühsam sein, insbesondere auf Plattformen wie PyBazaar, wo prägnante Zusammenfassungen die Benutzererfahrung verbessern. In diesem Beitrag erzähle ich, wie ich Simplemind und Gemini verwendet habe, um diesen Prozess in meinem Django-basierten Projekt zu automatisieren.
Hintergrundinformationen
Kürzlich habe ich PyBazaar.com gestartet, eine Website für Python-Entwickler, auf der sie ihre Fähigkeiten zeigen, Stellenangebote finden und Entwicklungsressourcen veröffentlichen und finden können. Sein Zweck besteht darin, einen zentralen Ort zu schaffen, an dem Python-Entwickler ihre Dienste, Produkte oder Projekte vermarkten können.
PyBazaar zeigt ausführliche Beschreibungen von Karrieremöglichkeiten und Ressourcen in den Detailansichten und kurze Zusammenfassungen in den Listenansichten. Zusammenfassungen helfen Benutzern, den Inhalt von Ressourcen und Karrieremöglichkeiten schnell zu erfassen, ohne jede Detailansicht öffnen zu müssen, und verbessern so das allgemeine Surferlebnis auf PyBazaar. Um die Bearbeitung reibungsloser zu gestalten, habe ich eine automatische Zusammenfassung auf Basis von KI eingeführt.
Wählen Sie Simplemind für die Kommunikation mit LLMs
Kenneth Reitz, der Autor des berühmten Pakets requests, hat kürzlich seine neueste Kreation – Simplemind – veröffentlicht, die die Entwicklererfahrung mit den APIs großer Sprachmodelle (LLMs) verbessert. Ich dachte, es wäre eine gute Gelegenheit, zu versuchen, sein Paket in PyBazaar zu integrieren.
Während ich Google Gemini für die kostenlose Stufe ausgewählt habe, bedeutet die Unterstützung von Simplemind für Anbieter wie OpenAI oder Claude, dass Entwickler bei Bedarf für erweiterte Funktionen oder präzisere Ergebnisse skalieren können.
API-Schlüssel einrichten
Zuerst musste ich mir einen API-Schlüssel bei Google AI Studio besorgen.
Django-Integration
Dann habe ich Simplemind:
installiert
(venv)$ pip install 'simplemind[full]'
Während ich jedoch darauf wartete, dass eine der Abhängigkeiten (grpcio) auf meinem Mac kompiliert wurde, hatte ich Zeit für einen Energy-Drink und genug Zeit, durch die Hälfte meines Social-Media-Feeds zu scrollen.
Simplemind erwartet, dass die LLM-API-Schlüssel in den Umgebungsvariablen definiert werden. In meinen Django-Projekten speichere ich die Geheimnisse in JSON-Dateien, die Git ignoriert, und lese diese Werte mit einer von mir geschriebenen Dienstprogrammfunktion get_secret().
Also habe ich diese Zeilen in den Django-Einstellungen hinzugefügt:
import os os.environ["GEMINI_API_KEY"] = get_secret("GEMINI_API_KEY") DEFAULT_LLM_PROVIDER = "gemini"
Ich habe eine unkomplizierte Ansicht erstellt, die gepostete HTML-Inhalte aufnimmt, LLM auffordert, diese zusammenzufassen, und die Zusammenfassung an den Benutzer zurückgibt:
import json import simplemind from django.contrib.auth.decorators import login_required from django.conf import settings from django.http import JsonResponse from django.utils.html import strip_tags @login_required def summarize(request): summary = "" try: if ( request.method == "POST" and (data := json.loads(request.body)) and (content := data.get("content")) and (text := strip_tags(content).strip()) ): summary = simplemind.generate_text( prompt=f"Condense the following information in 2 sentences:\n\n{text}", llm_provider=settings.DEFAULT_LLM_PROVIDER, ).strip() except json.JSONDecodeError: pass data = {"summary": summary} return JsonResponse(data)
Wie Sie sehen, ist Simplemind genauso elegant wie die Anfragen-App. Ich könnte problemlos zu OpenAI oder Claude wechseln, wenn ich erweiterte Ergebnisse oder intelligentere Abfragen benötige.
Ich habe „strip_tags()“ verwendet, um die Tokenanzahl zu reduzieren, und „strip()“, um führende und nachfolgende Leerzeichen zu entfernen.
Um die Leistung der Ansicht zu verbessern, könnte ich auch ASGI oder eine Hintergrundaufgabe verwenden, aber das sollte man berücksichtigen, wenn es mehr Benutzer bei PyBazaar gibt.
Die Zusammenfassungsschaltfläche hatte ihre eigene Vorlage, die ich in mein Django Crispy Forms-Layout mit layout.HTML("""{% include "summarizer/includes/summarize_button.html" %}"""):
eingebunden habe
(venv)$ pip install 'simplemind[full]'
Wenn ein Benutzer auf die Schaltfläche „Durch KI zusammenfassen“ klickt, deaktiviert das Javascript die Schaltfläche vorübergehend, ändert seinen Text in „Zusammenfassen …“, liest den HTML-Wert aus dem QuillJS-Feld und veröffentlicht ihn als {"content ": "..."} zur Zusammenfassungsansicht. Nachdem die Zusammenfassung als {"summary": "..."} empfangen wurde, füllt das Javascript den Zusammenfassungstextbereich aus und macht die Schaltfläche wieder anklickbar.
Abschluss
Simplemind erleichtert die Arbeit mit LLMs durch intelligente Standardeinstellungen, sodass Entwickler keine komplizierten Einstellungen wie Temperatur oder max_tokens anpassen müssen.
Gemini LLM kann kostenlos genutzt werden, und das scheint für einfache Funktionen wie diese bei einer moderaten Anzahl aktiver Benutzer ausreichend zu sein.
Ich habe diese Zusammenfassungsfunktion bei PyBazaar in nur einem halben Tag implementiert und konnte diese Integration problemlos anpassen, um Meta-Beschreibungen, E-Mail-Entwürfe oder personalisierte Empfehlungen zu generieren.
Wenn Sie ein Python-Entwickler sind, der Ihre Fähigkeiten unter Beweis stellen, Ressourcen teilen oder Möglichkeiten finden möchte, besuchen Sie noch heute PyBazaar.com!
Titelfoto von Caio
Das obige ist der detaillierte Inhalt vonErstellen von KI-basierten Zusammenfassungen in einer Django-Website. 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

Häufig gestellte Fragen und Lösungen für das Ticket-Ticket-Ticket-Ticket in Front-End im Front-End-Entwicklungsdruck ist der Ticketdruck eine häufige Voraussetzung. Viele Entwickler implementieren jedoch ...

JavaScript ist der Eckpfeiler der modernen Webentwicklung. Zu den Hauptfunktionen gehören eine ereignisorientierte Programmierung, die Erzeugung der dynamischen Inhalte und die asynchrone Programmierung. 1) Ereignisgesteuerte Programmierung ermöglicht es Webseiten, sich dynamisch entsprechend den Benutzeroperationen zu ändern. 2) Die dynamische Inhaltsgenerierung ermöglicht die Anpassung der Seiteninhalte gemäß den Bedingungen. 3) Asynchrone Programmierung stellt sicher, dass die Benutzeroberfläche nicht blockiert ist. JavaScript wird häufig in der Webinteraktion, der einseitigen Anwendung und der serverseitigen Entwicklung verwendet, wodurch die Flexibilität der Benutzererfahrung und die plattformübergreifende Entwicklung erheblich verbessert wird.

Es gibt kein absolutes Gehalt für Python- und JavaScript -Entwickler, je nach Fähigkeiten und Branchenbedürfnissen. 1. Python kann mehr in Datenwissenschaft und maschinellem Lernen bezahlt werden. 2. JavaScript hat eine große Nachfrage in der Entwicklung von Front-End- und Full-Stack-Entwicklung, und sein Gehalt ist auch beträchtlich. 3. Einflussfaktoren umfassen Erfahrung, geografische Standort, Unternehmensgröße und spezifische Fähigkeiten.

Wie fusioniere ich Array -Elemente mit derselben ID in ein Objekt in JavaScript? Bei der Verarbeitung von Daten begegnen wir häufig die Notwendigkeit, dieselbe ID zu haben ...

JavaScript zu lernen ist nicht schwierig, aber es ist schwierig. 1) Verstehen Sie grundlegende Konzepte wie Variablen, Datentypen, Funktionen usw. 2) Beherrschen Sie die asynchrone Programmierung und implementieren Sie sie durch Ereignisschleifen. 3) Verwenden Sie DOM -Operationen und versprechen Sie, asynchrone Anfragen zu bearbeiten. 4) Vermeiden Sie häufige Fehler und verwenden Sie Debugging -Techniken. 5) Die Leistung optimieren und Best Practices befolgen.

Diskussion über die Realisierung von Parallaxe -Scrolling- und Elementanimationseffekten in diesem Artikel wird untersuchen, wie die offizielle Website der Shiseeido -Website (https://www.shiseeido.co.jp/sb/wonderland/) ähnlich ist ...

Zu den neuesten Trends im JavaScript gehören der Aufstieg von Typenkripten, die Popularität moderner Frameworks und Bibliotheken und die Anwendung der WebAssembly. Zukunftsaussichten umfassen leistungsfähigere Typsysteme, die Entwicklung des serverseitigen JavaScript, die Erweiterung der künstlichen Intelligenz und des maschinellen Lernens sowie das Potenzial von IoT und Edge Computing.

Eingehende Diskussion der Ursachen des Unterschieds in der Konsole.log-Ausgabe. In diesem Artikel wird die Unterschiede in den Ausgabeergebnissen der Konsolenfunktion in einem Code analysiert und die Gründe dafür erläutert. � ...
