Yandex Cloud
Поиск
Связаться с намиПодключиться
  • Документация
  • Блог
  • Все сервисы
  • Статус работы сервисов
    • Популярные
    • Инфраструктура и сеть
    • Платформа данных
    • Контейнеры
    • Инструменты разработчика
    • Бессерверные вычисления
    • Безопасность
    • Мониторинг и управление ресурсами
    • Машинное обучение
    • Бизнес-инструменты
  • Все решения
    • По отраслям
    • По типу задач
    • Экономика платформы
    • Безопасность
    • Техническая поддержка
    • Каталог партнёров
    • Обучение и сертификация
    • Облако для стартапов
    • Облако для крупного бизнеса
    • Центр технологий для общества
    • Облако для интеграторов
    • Поддержка IT-бизнеса
    • Облако для фрилансеров
    • Обучение и сертификация
    • Блог
    • Документация
    • Контент-программа
    • Мероприятия и вебинары
    • Контакты, чаты и сообщества
    • Идеи
    • Истории успеха
    • Тарифы Yandex Cloud
    • Промоакции и free tier
    • Правила тарификации
  • Документация
  • Блог
Проект Яндекса
© 2025 ООО «Яндекс.Облако»
Yandex SpeechKit
  • Обзор технологий SpeechKit
    • Распознавание речи с помощью Playground
    • Синтез речи с помощью Playground
      • Потоковое распознавание аудиофайла API v3
      • Потоковое распознавание речи с микрофона API v3
      • Автоматическое определение языка — API v3
      • Потоковое распознавание API v2
      • Синхронное распознавание API v1
      • Асинхронное распознавание аудиофайлов в формате WAV — API v3
      • Асинхронное распознавание формата LPCM — API v2
      • Асинхронное распознавание формата OggOpus — API v2
      • Регулярное асинхронное распознавание аудиофайлов — API v2
  • Поддерживаемые форматы аудио
  • Интеграция телефонии
  • Квоты и лимиты
  • Управление доступом
  • Правила тарификации

В этой статье:

  • Автоматическое определение языка
  • Подготовьте необходимые ресурсы
  • Создайте приложение для потокового распознавания речи
  1. Пошаговые инструкции
  2. Распознавание
  3. Автоматическое определение языка — API v3

Потоковое распознавание речи с автоматическим определением языка в API v3

Статья создана
Yandex Cloud
Улучшена
Dmitry A.
Обновлена 14 апреля 2025 г.
  • Автоматическое определение языка
  • Подготовьте необходимые ресурсы
  • Создайте приложение для потокового распознавания речи

Пример показывает, как с помощью API v3 SpeechKit в режиме реального времени распознать речь в формате LPCM с автоматическим определением языка (языков).

В примере заданы следующие параметры:

  • язык распознавания — auto (автоматическое определение языка);
  • формат аудиопотока — LPCM с частотой дискретизации 8000 Гц;
  • количество аудиоканалов — 1 (значение по умолчанию);
  • остальные параметры оставлены по умолчанию.

Автоматическое определение языкаАвтоматическое определение языка

Сервис SpeechKit в ходе распознавания речи автоматически определяет язык в каждом отдельном предложении.

Чтобы настроить автоматическое определение языка, в параметре language_code метода LanguageRestrictionOptions() укажите значение auto:

Python 3
language_restriction=stt_pb2.LanguageRestrictionOptions(
      restriction_type=stt_pb2.LanguageRestrictionOptions.WHITELIST,
      language_code=['auto']
)

Вместе с результатами распознавания сервис возвращает языковые метки, содержащие код языка и вероятность правильности его определения:

language_code: "ru-RU" probability: 0.91582357883453369

Если одно предложение состоит из слов на разных языках, то язык может быть определен неверно. Для улучшения результатов добавьте список ожидаемых языков как подсказку для модели. Например:

Python 3
...
      language_code=['auto', 'en-US', 'es-ES', 'fr-FR']
...

Примечание

Определение языка и расстановка языковых меток доступно только в gRPC API v3.

Примеры

Текст в аудио Транскрибация
Открой Whats'app Открой ватсап
Это можно настроить в Windows Hello или другом сервисе Это можно настроить в виндс хеллоу или другом сервисе
Men koʻchada sayr qilishni va muzqaymoq isteʼmol qilishni yaxshi koʻraman, я люблю гулять по улице и есть мороженое Men koʻchada sayr qilishni va muzqaymoq isteʼmol qilishni yaxshi koʻraman, я люблю гулять по улице и есть мороженое

Подготовьте необходимые ресурсыПодготовьте необходимые ресурсы

  1. Создайте сервисный аккаунт и назначьте ему роль ai.speechkit-stt.user.
  2. Для сервисного аккаунта получите и сохраните IAM-токен.
  3. Скачайте пример аудиофайла для распознавания или сгенерируйте свой.

Создайте приложение для потокового распознавания речиСоздайте приложение для потокового распознавания речи

Чтобы реализовать пример из этого раздела:

  1. Склонируйте репозиторий Yandex Cloud API:

    git clone https://github.com/yandex-cloud/cloudapi
    
  2. Создайте клиентское приложение:

    Python 3
    1. Установите пакет grpcio-tools с помощью менеджера пакетов pip:

      pip install grpcio-tools
      
    2. Перейдите в папку со склонированным репозиторием Yandex Cloud API, создайте папку output и сгенерируйте в ней код интерфейса клиента:

      cd <путь_к_папке_cloudapi>
      mkdir output
      python3 -m grpc_tools.protoc -I . -I third_party/googleapis \
          --python_out=output \
          --grpc_python_out=output \
          google/api/http.proto \
          google/api/annotations.proto \
          yandex/cloud/api/operation.proto \
          google/rpc/status.proto \
          yandex/cloud/operation/operation.proto \
          yandex/cloud/validation.proto \
          yandex/cloud/ai/stt/v3/stt_service.proto \
          yandex/cloud/ai/stt/v3/stt.proto
      

      В результате в папке output будут созданы файлы с интерфейсом клиента: stt_pb2.py, stt_pb2_grpc.py, stt_service_pb2.py, stt_service_pb2_grpc.py и файлы зависимостей.

    3. Создайте файл в корне папки output, например test.py, и добавьте в него следующий код:

      #coding=utf8
      import argparse
      
      import grpc
      
      import yandex.cloud.ai.stt.v3.stt_pb2 as stt_pb2
      import yandex.cloud.ai.stt.v3.stt_service_pb2_grpc as stt_service_pb2_grpc
      
      CHUNK_SIZE = 4000
      
      def gen(audio_file_name):
          # Задайте настройки распознавания.
          recognize_options = stt_pb2.StreamingOptions(
              recognition_model=stt_pb2.RecognitionModelOptions(
                  audio_format=stt_pb2.AudioFormatOptions(
                      raw_audio=stt_pb2.RawAudio(
                          audio_encoding=stt_pb2.RawAudio.LINEAR16_PCM,
                          sample_rate_hertz=8000,
                          audio_channel_count=1
                      )
                  ),
                  # Задайте автоматическое распознавание языков.
                  language_restriction=stt_pb2.LanguageRestrictionOptions(
                      restriction_type=stt_pb2.LanguageRestrictionOptions.WHITELIST,
                      language_code=['auto']
                  ),
                  # Выберите модели распознавание — потоковое распознавание.
                  audio_processing_type=stt_pb2.RecognitionModelOptions.REAL_TIME
              )
          )
      
          # Отправьте сообщение с настройками распознавания.
          yield stt_pb2.StreamingRequest(session_options=recognize_options)
      
          # Прочитайте аудиофайл и отправьте его содержимое порциями.
          with open(audio_file_name, 'rb') as f:
              data = f.read(CHUNK_SIZE)
              while data != b'':
                  yield stt_pb2.StreamingRequest(chunk=stt_pb2.AudioChunk(data=data))
                  data = f.read(CHUNK_SIZE)
      
      # Вместо iam_token передавайте api_key при аутентификации с API-ключом
      # от имени сервисного аккаунта.
      # def run(api_key, audio_file_name):
      def run(iam_token, audio_file_name):
          # Установите соединение с сервером.
          cred = grpc.ssl_channel_credentials()
          channel = grpc.secure_channel('stt.api.cloud.yandex.net:443', cred)
          stub = stt_service_pb2_grpc.RecognizerStub(channel)
      
          # Отправьте данные для распознавания.
          it = stub.RecognizeStreaming(gen(audio_file_name), metadata=(
          # Параметры для аутентификации с IAM-токеном
              ('authorization', f'Bearer {iam_token}'),
          # Параметры для аутентификации с API-ключом от имени сервисного аккаунта
          #   ('authorization', f'Api-Key {api_key}'),
          ))
      
          # Обработайте ответы сервера и выведите результат в консоль.
          try:
              for r in it:
                  event_type, alternatives = r.WhichOneof('Event'), None
                  if event_type == 'partial' and len(r.partial.alternatives) > 0:
                      alternatives = [a.text for a in r.partial.alternatives]
                  if event_type == 'final':
                      alternatives = [a.text for a in r.final.alternatives]
                      # Получение языковых меток:
                      langs = [a.languages for a in r.final.alternatives]
                  if event_type == 'final_refinement':
                      alternatives = [a.text for a in r.final_refinement.normalized_text.alternatives]
                  print(f'type={event_type}, alternatives={alternatives}')
                  # Вывод в консоль языковых меток для финальных версий:
                  if event_type == 'final':
                      print(f'Language labels:')
                      for lang in langs:
                          for line in lang:
                              words=f'{line}'.splitlines()
                              for word in words:
                                  print(f'  {word}', end="")
                              print()
          except grpc._channel._Rendezvous as err:
              print(f'Error code {err._state.code}, message: {err._state.details}')
              raise err
      
      if __name__ == '__main__':
          parser = argparse.ArgumentParser()
          parser.add_argument('--token', required=True, help='IAM token or API key')
          parser.add_argument('--path', required=True, help='audio file path')
          args = parser.parse_args()
          run(args.token, args.path)
      

      Где:

      • audio_encoding — формат аудиопотока.
      • sample_rate_hertz — частота дискретизации аудиопотока.
      • audio_channel_count — количество аудиоканалов.
      • language_code — язык, для которого будет выполнено распознавание.
  3. Задайте IAM-токен сервисного аккаунта:

    export IAM_TOKEN=<IAM-токен_сервисного_аккаунта>
    
  4. Выполните созданный файл:

    python3 output/test.py --token ${IAM_TOKEN} --path <путь_к_файлу_speech.pcm>
    

    Где --path — путь к аудиофайлу, который необходимо распознать.

    Результат:

    type=status_code, alternatives=None
    type=partial, alternatives=None
    type=partial, alternatives=['привет']
    type=final, alternatives=['привет мир']
    Language guess:
        language_code: "ru-RU"  probability: 1
    type=final_refinement, alternatives=['привет мир']
    type=eou_update, alternatives=None
    type=partial, alternatives=None
    type=status_code, alternatives=None
    

См. такжеСм. также

  • Справочник API v3
  • Аутентификация в API SpeechKit
  • Поддерживаемые языки и модели распознавания

Была ли статья полезна?

Предыдущая
Потоковое распознавание речи с микрофона API v3
Следующая
Потоковое распознавание API v2
Проект Яндекса
© 2025 ООО «Яндекс.Облако»