Sari95's picture
Update prompt instruction
c4be13a verified
raw
history blame
1.47 kB
import gradio as gr
import requests
import os # Importiere das os-Modul, um Secrets zu verwenden
# Hugging Face API Key wird aus den Hugging Face Secrets geladen
HF_API_KEY = os.getenv("IBMGraniteTextSummary")
# IBM Granite 3B Modell
MODEL_NAME = "ibm-granite/granite-3.1-1b-a400m-instruct"
# Funktion zur Textzusammenfassung
def summarize_text(text):
if not HF_API_KEY:
return "Fehler: Kein API-Key gefunden. Bitte überprüfe die Hugging Face Secrets."
url = f"https://api-inference.huggingface.co/models/{MODEL_NAME}"
headers = {"Authorization": f"Bearer {HF_API_KEY}"}
prompt = f"Summarize the following text in 5 sentences. Concentrate on the main points.:\n\n{text}"
payload = {"inputs": prompt}
response = requests.post(url, headers=headers, json=payload)
if response.status_code == 200:
result = response.json()
return result[0]["generated_text"] if result else "Keine Antwort erhalten."
else:
return f"Fehler: {response.status_code} - {response.text}"
# Gradio UI
iface = gr.Interface(
fn=summarize_text,
inputs=gr.Textbox(label="Gib deinen Text ein", lines=5),
outputs=gr.Textbox(label="Zusammenfassung"),
title="IBM Granite Text Summarizer",
description="Dieses Tool nutzt IBM Granite-3B, um Texte zusammenzufassen. Gib einen langen Text ein, und Granite erstellt eine kurze Zusammenfassung!"
)
# App starten
if __name__ == "__main__":
iface.launch()