将音频文件传递给watson websocket时出错:[SSL:BAD_LENGTH]错误长度(_ssl.c:2341)

问题描述 投票:1回答:1

我正在尝试使用watson语音到文本api来识别音频文件中“manager”,“warranty”和“replace”的用法。我得到的错误是神秘的:

收到错误:[SSL:BAD_LENGTH]错误长度(_ssl.c:2341)

from __future__ import print_function
import json
from os.path import join, dirname
from ibm_watson import SpeechToTextV1
from ibm_watson.websocket import RecognizeCallback, AudioSource

speech_to_text = SpeechToTextV1(
    iam_apikey="__nunya__",
    url="__nunya__"
)

class MyRecognizeCallback(RecognizeCallback):
    def __init__(self):
        RecognizeCallback.__init__(self)

    def on_data(self, data):
        print(json.dumps(data, indent=2))

    def on_error(self, error):
        print('Error received: {}'.format(error))

    def on_inactivity_timeout(self, error):
        print('Inactivity timeout: {}'.format(error))

myRecognizeCallback = MyRecognizeCallback()

with open(join(dirname(__file__), './.', 'AudioRecordings/ComputerSupportCall.mp3'),
              'rb') as audio_file:
    audio_source = AudioSource(audio_file)
    speech_to_text.recognize_using_websocket(
        audio=audio_source,
        content_type='audio/mp3',
        recognize_callback=myRecognizeCallback,
        model='en-US_BroadbandModel',
        keywords=['manager', 'warranty', 'replace'],
        keywords_threshold=0.5,
        max_alternatives=3)

我想要回来的是这种格式的回复:

      "keywords_result": {
        "manager": [
          {
            "normalized_text": "manager",
            "start_time": 1.52,
            "end_time": 2.15,
            "confidence": 0.978
          }
        ], (etc ...)
ibm-watson speech-to-text
1个回答
1
投票

当然我在发布后找到答案......文件路径不正确,应该是:

with open(join(dirname(__file__), 'AudioRecordings/ComputerSupportCall.mp3')
              'rb') as audio_file:
© www.soinside.com 2019 - 2024. All rights reserved.