Home  >  Article  >  Backend Development  >  Exploring Async Deepgram API: Speech-to-Text using Python

Exploring Async Deepgram API: Speech-to-Text using Python

Patricia Arquette
Patricia ArquetteOriginal
2024-10-21 18:16:30573browse

Today will explore the Deepgram API for converting voice to text [transcription]. Whether building a voice assistant, transcribing meetings or creating a voice-controlled app, Deepgram makes it easier than ever to get started.

Exploring Async Deepgram API: Speech-to-Text using Python

What is Deepgram?

Deepgram is a powerful speech recognition platform that uses advanced machine learning models to transcribe audio in real-time. It offers an easy-to-use API that developers can integrate into their applications for tasks like transcribing phone calls, converting meetings into text, or even analyzing customer interactions.

Why Use Deepgram?

  • Accuracy: Deepgram boasts high accuracy rates thanks to its deep learning algorithms trained on vast datasets.

  • Real-Time Transcription: Get instant results as you speak, perfect for live applications.

  • Multiple Languages: Supports several languages and accents, making it versatile for global applications.

Getting Started with Deepgram API

Install - pip install httpx

Importing Required Libraries

import httpx
import asyncio
import logging
import traceback

Defining the Asynchronous Function

#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
    }

4. Sending the Asynchronous Request

    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

We create an instance of httpx.AsyncClient with a timeout of 60 seconds. Using async with ensures that the client is properly closed after the block is executed.
If the request is successful, we parse the JSON response and log it, then return the result.

Call back URL :

You can use for sample call back URL for testing.

conclusion:

This structured approach highlights how to utilize asynchronous programming in Python to interact with the Deepgram API efficiently. By breaking the code into blocks and explaining each part, readers can better understand the implementation and how to adapt it to their own needs.

The above is the detailed content of Exploring Async Deepgram API: Speech-to-Text using Python. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn