轉錄音訊內容

本頁說明如何使用 Google Distributed Cloud (GDC) 無網路連線裝置上的 Speech-to-Text API,將音訊檔案轉錄為文字。

GDC air-gapped 裝置上的 Vertex AI 語音轉文字服務可辨識音訊檔案中的語音。語音轉文字會使用預先訓練的 API,將偵測到的音訊轉換為文字轉錄稿。

事前準備

您必須擁有已啟用 Speech-to-Text API 的專案,並具備適當的憑證,才能開始使用 Speech-to-Text API。您也可以安裝用戶端程式庫,協助呼叫 API。詳情請參閱「設定語音辨識專案」。

使用預設模型轉錄音訊

Speech-to-Text 會執行語音辨識,您直接將要辨識語音的音訊檔案做為 API 要求的內容傳送。系統會在 API 回應中傳回轉錄結果。

提出語音辨識要求時,您必須提供 RecognitionConfig 設定物件。這個物件會告知 API 如何處理音訊資料,以及您預期的輸出類型。如果這個設定物件中未明確指定模型,Speech-to-Text 會選取預設模型。GDC 實體隔離裝置上的語音轉文字功能僅支援預設模型。

請按照下列步驟操作,透過 Python 指令碼使用 Speech-to-Text 服務,轉錄音訊檔案中的語音:

  1. 安裝最新版本的 Speech-to-Text 用戶端程式庫

  2. 在 Python 指令碼中設定必要的環境變數

  3. 驗證 API 要求

  4. 在您建立的 Python 指令碼中新增下列程式碼:

    import base64
    
    from google.cloud import speech_v1p1beta1
    import google.auth
    from google.auth.transport import requests
    from google.api_core.client_options import ClientOptions
    
    audience="https://ENDPOINT:443"
    api_endpoint="ENDPOINT:443"
    
    def get_client(creds):
      opts = ClientOptions(api_endpoint=api_endpoint)
      return speech_v1p1beta1.SpeechClient(credentials=creds, client_options=opts)
    
    def main():
      creds = None
      try:
        creds, project_id = google.auth.default()
        creds = creds.with_gdch_audience(audience)
        req = requests.Request()
        creds.refresh(req)
        print("Got token: ")
        print(creds.token)
      except Exception as e:
        print("Caught exception" + str(e))
        raise e
      return creds
    
    def speech_func(creds):
      tc = get_client(creds)
    
      content="BASE64_ENCODED_AUDIO"
    
      audio = speech_v1p1beta1.RecognitionAudio()
      audio.content = base64.standard_b64decode(content)
      config = speech_v1p1beta1.RecognitionConfig()
      config.encoding= speech_v1p1beta1.RecognitionConfig.AudioEncoding.ENCODING
      config.sample_rate_hertz=RATE_HERTZ
      config.language_code="LANGUAGE_CODE"
      config.audio_channel_count=CHANNEL_COUNT
    
      metadata = [("x-goog-user-project", "projects/PROJECT_ID")]
      resp = tc.recognize(config=config, audio=audio, metadata=metadata)
      print(resp)
    
    if __name__=="__main__":
      creds = main()
      speech_func(creds)
    

    更改下列內容:

    • ENDPOINT:貴機構使用的 Speech-to-Text 端點。詳情請參閱服務狀態和端點
    • PROJECT_ID:您的專案 ID。
    • BASE64_ENCODED_AUDIO:以 Base64 表示法編碼的音訊資料位元組。這個字串開頭的字元與 ZkxhQwAAACIQABAAAAUJABtAA+gA8AB+W8FZndQvQAyjv 類似。
    • ENCODING:要求中傳送的音訊資料編碼,例如 LINEAR16
    • RATE_HERTZ:要求中傳送的音訊資料取樣率 (赫茲),例如 16000
    • LANGUAGE_CODE:以 BCP-47 語言標記形式提供的音訊語言。請參閱支援的語言清單和對應的語言代碼。
    • CHANNEL_COUNT:輸入音訊資料中的聲道數量,例如 1
  5. 儲存 Python 指令碼。

  6. 執行 Python 指令碼來轉錄音訊:

    python SCRIPT_NAME
    

    SCRIPT_NAME 替換為您為 Python 指令碼指定的名稱,例如 speech.py