Trascrizione di audio dall'input in streaming

Questa sezione mostra come trascrivere in testo l'audio in streaming, ad esempio l'input di un microfono.

Il riconoscimento vocale in streaming ti consente di trasmettere audio in streaming a Speech-to-Text e di ricevere i risultati del riconoscimento vocale in streaming in tempo reale durante l'elaborazione dell'audio. Vedi anche i limiti audio per lo streaming delle richieste di riconoscimento vocale. Il riconoscimento vocale in streaming è disponibile soltanto tramite gRPC.

Prima di iniziare

  1. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Go to project selector

  2. Assicurati che la fatturazione sia attivata per il tuo progetto Google Cloud.

  3. Abilita le API Speech-to-Text.

    Abilita le API

  4. Make sure that you have the following role or roles on the project: Cloud Speech Administrator

    Check for the roles

    1. In the Google Cloud console, go to the IAM page.

      Go to IAM
    2. Select the project.
    3. In the Principal column, find all rows that identify you or a group that you're included in. To learn which groups you're included in, contact your administrator.

    4. For all rows that specify or include you, check the Role colunn to see whether the list of roles includes the required roles.

    Grant the roles

    1. In the Google Cloud console, go to the IAM page.

      Vai a IAM
    2. Seleziona il progetto.
    3. Fai clic su Concedi l'accesso.
    4. Nel campo Nuove entità, inserisci l'identificatore utente. In genere si tratta dell'indirizzo email di un Account Google.

    5. Nell'elenco Seleziona un ruolo, seleziona un ruolo.
    6. Per concedere altri ruoli, fai clic su Aggiungi un altro ruolo e aggiungiamo ogni altro ruolo.
    7. Fai clic su Salva.
    8. Install the Google Cloud CLI.
    9. To initialize the gcloud CLI, run the following command:

      gcloud init
    10. Le librerie client possono utilizzare le credenziali predefinite dell'applicazione per autenticarsi facilmente con le API di Google e inviare richieste a queste API. Con Credenziali predefinite dell'applicazione, puoi testare l'applicazione in locale ed eseguirne il deployment senza modificare il codice sottostante. Per ulteriori informazioni, consulta <atrack-type="common generate" l10n-attrs-original-order="href,track-type,track-name" l10n-encrypted-href="WDE63JFVMK0YqIWBqG8nCycgwkRfOeEqRvzYs1N+2tJUEhcZvE5WLink-reference for AuthenticatehcZvE5WLink-reference for Authenticate

    11. Create local authentication credentials for your user account:

      gcloud auth application-default login

    Assicurati inoltre di aver installato la libreria client.

    Esecuzione del riconoscimento vocale in streaming su un file locale

    Di seguito è riportato un esempio di riconoscimento vocale in streaming su un file audio locale. Esiste un limite di 25 kB per l'audio inviato nelle richieste di uno stream. Questo limite si applica sia alla richiesta StreamingRecognize iniziale sia alle dimensioni di ogni singolo messaggio nel flusso. Il superamento di questo limite causerà un errore.

    Python

    from google.cloud.speech_v2 import SpeechClient
    from google.cloud.speech_v2.types import cloud_speech as cloud_speech_types
    
    def transcribe_streaming_v2(
        project_id: str,
        audio_file: str,
    ) -> cloud_speech_types.StreamingRecognizeResponse:
        """Transcribes audio from audio file stream.
    
        Args:
            project_id: The GCP project ID.
            audio_file: The path to the audio file to transcribe.
    
        Returns:
            The response from the transcribe method.
        """
        # Instantiates a client
        client = SpeechClient()
    
        # Reads a file as bytes
        with open(audio_file, "rb") as f:
            content = f.read()
    
        # In practice, stream should be a generator yielding chunks of audio data
        chunk_length = len(content) // 5
        stream = [
            content[start : start + chunk_length]
            for start in range(0, len(content), chunk_length)
        ]
        audio_requests = (
            cloud_speech_types.StreamingRecognizeRequest(audio=audio) for audio in stream
        )
    
        recognition_config = cloud_speech_types.RecognitionConfig(
            auto_decoding_config=cloud_speech_types.AutoDetectDecodingConfig(),
            language_codes=["en-US"],
            model="long",
        )
        streaming_config = cloud_speech_types.StreamingRecognitionConfig(
            config=recognition_config
        )
        config_request = cloud_speech_types.StreamingRecognizeRequest(
            recognizer=f"projects/{project_id}/locations/global/recognizers/_",
            streaming_config=streaming_config,
        )
    
        def requests(config: cloud_speech_types.RecognitionConfig, audio: list) -> list:
            yield config
            yield from audio
    
        # Transcribes the audio into text
        responses_iterator = client.streaming_recognize(
            requests=requests(config_request, audio_requests)
        )
        responses = []
        for response in responses_iterator:
            responses.append(response)
            for result in response.results:
                print(f"Transcript: {result.alternatives[0].transcript}")
    
        return responses
    
    

    Sebbene sia possibile trasmettere in streaming un file audio locale all'API Speech-to-Text, ti consigliamo di eseguire il riconoscimento audio sincrono.

    Esegui la pulizia

    Per evitare che al tuo account Google Cloud vengano addebitati costi relativi alle risorse utilizzate in questa pagina, segui questi passaggi.

    1. Facoltativo: revoca le credenziali di autenticazione che hai creato ed elimina il file delle credenziali locale.

      gcloud auth application-default revoke
    2. Facoltativo: revoca le credenziali dallgcloud CLI.

      gcloud auth revoke

    Console

  5. Nella console Google Cloud, vai alla pagina Gestisci risorse.

    Vai a Gestisci risorse

  6. Nell'elenco dei progetti, seleziona il progetto che vuoi eliminare, quindi fai clic su Elimina.
  7. Nella finestra di dialogo, digita l'ID del progetto e fai clic su Chiudi per eliminare il progetto.
  8. gcloud

    Elimina un progetto Google Cloud:

    gcloud projects delete PROJECT_ID

    Passaggi successivi