Heim >Backend-Entwicklung >Python-Tutorial >Erkundung der Async Deepgram API: Speech-to-Text mit Python
Heute wird die Deepgram-API zum Konvertieren von Sprache in Text [Transkription] untersucht. Ob Sie einen Sprachassistenten erstellen, Meetings transkribieren oder eine sprachgesteuerte App erstellen, Deepgram macht den Einstieg einfacher als je zuvor.
Deepgram ist eine leistungsstarke Spracherkennungsplattform, die fortschrittliche Modelle des maschinellen Lernens verwendet, um Audio in Echtzeit zu transkribieren. Es bietet eine benutzerfreundliche API, die Entwickler in ihre Anwendungen integrieren können, um Aufgaben wie das Transkribieren von Telefonanrufen, das Umwandeln von Besprechungen in Text oder sogar das Analysieren von Kundeninteraktionen zu erledigen.
Genauigkeit: Deepgram verfügt dank seiner Deep-Learning-Algorithmen, die auf riesigen Datensätzen trainiert wurden, über hohe Genauigkeitsraten.
Echtzeit-Transkription: Erhalten Sie sofortige Ergebnisse, während Sie sprechen, perfekt für Live-Anwendungen.
Mehrere Sprachen: Unterstützt mehrere Sprachen und Akzente und ist somit vielseitig für globale Anwendungen.
Installieren – pip install httpx
import httpx import asyncio import logging import traceback
#recording_url: The URL of the audio file to be transcribed. #callback_url: The URL to which Deepgram will send the #transcription results (optional). #api_key: Your Deepgram API key. async def transcribe_audio(recording_url: str, callback_url: str, api_key: str): url = "https://api.deepgram.com/v1/listen" # Define headers headers = { "Authorization": f"Token {api_key}" } # Define query parameters query_params = { "callback_method": "post", "callback": callback_url } # Define body parameters body_params = { "url": recording_url }
logger.info(f"Sending request to {url} with headers: {headers}, query: {query_params}, body: {body_params}") async with httpx.AsyncClient(timeout=60.0) as client: try: # Make a POST request with query parameters and body response = await client.post(url, headers=headers, params=query_params, json=body_params) response.raise_for_status() # Raise an error for HTTP error responses result = response.json() logger.info(f"Response received: {result}") return result
Wir erstellen eine Instanz von httpx.AsyncClient mit einem Timeout von 60 Sekunden. Durch die Verwendung von async with wird sichergestellt, dass der Client ordnungsgemäß geschlossen wird, nachdem der Block ausgeführt wurde.
Wenn die Anfrage erfolgreich ist, analysieren wir die JSON-Antwort, protokollieren sie und geben dann das Ergebnis zurück.
Sie können zum Testen eine Beispiel-Rückruf-URL verwenden.
Dieser strukturierte Ansatz zeigt, wie man asynchrone Programmierung in Python nutzt, um effizient mit der Deepgram-API zu interagieren. Durch die Aufteilung des Codes in Blöcke und die Erläuterung jedes Teils können Leser die Implementierung besser verstehen und wissen, wie sie sie an ihre eigenen Bedürfnisse anpassen können.
Das obige ist der detaillierte Inhalt vonErkundung der Async Deepgram API: Speech-to-Text mit Python. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!