如何从Telegram bot发送语音到wit.ai

时间:2018-04-15 08:16:00

标签: python telegram wit.ai

我试图使用wit.ai来理解Telegram机器人从用户收到的语音命令中的意图和实体。

def discover(bot, update, user_data):

   voice = bot.getFile(update.message.voice.file_id)
   voice.download('file.ogg')

   client = Wit(wit_access_token)

   with open('file.ogg', 'rb') as f:
       resp = client.speech(f, True, {'Content-Type': 'audio/ogg'})
   print('Yay, got Wit.ai response: ' + str(resp))

但是,我从Wit客户端收到此错误:

Traceback (most recent call last):
File "C:\Program Files\JetBrains\PyCharm Community Edition 2017.2.3\helpers\pydev\pydevd.py", line 1599, in <module>
globals = debugger.run(setup['file'], None, None, is_module)
File "C:\Program Files\JetBrains\PyCharm Community Edition 2017.2.3\helpers\pydev\pydevd.py", line 1026, in run
pydev_imports.execfile(file, globals, locals)  # execute the script
File "C:/Users/PAGANEFR/PycharmProjects/MARCoBot/readaudio.py", line 8, in <module>
resp = client.speech(f, True, {'Content-Type': 'audio/ogg'})
File "C:\Python27\lib\site-packages\wit\wit.py", line 88, in speech
data=audio_file, headers=headers)
File "C:\Python27\lib\site-packages\wit\wit.py", line 41, in req
' (' + rsp.reason + ')')
wit.wit.WitError: Wit responded with status: 400 (Bad Request)

我可以用VLC播放ogg文件。文件似乎一致。 我试图用声音文件库将ogg文件转换为wav:

data, samplerate = sf.read('file.ogg')
sf.write('file.wav', data, samplerate)

但是我收到了这个错误:

Traceback (most recent call last):
File "C:\Program Files\JetBrains\PyCharm Community Edition 2017.2.3\helpers\pydev\pydevd.py", line 1599, in <module>
globals = debugger.run(setup['file'], None, None, is_module)
File "C:\Program Files\JetBrains\PyCharm Community Edition 2017.2.3\helpers\pydev\pydevd.py", line 1026, in run
pydev_imports.execfile(file, globals, locals)  # execute the script
File "C:/Users/PAGANEFR/PycharmProjects/MARCoBot/readaudio.py", line 6, in <module>
data = sf.read('file.ogg')
File "C:\Python27\lib\site-packages\soundfile.py", line 257, in read
subtype, endian, format, closefd) as f:
File "C:\Python27\lib\site-packages\soundfile.py", line 624, in __init__
self._file = self._open(file, mode_int, closefd)
File "C:\Python27\lib\site-packages\soundfile.py", line 1179, in _open
"Error opening {0!r}: ".format(self.name))
File "C:\Python27\lib\site-packages\soundfile.py", line 1352, in _error_check
raise RuntimeError(prefix + _ffi.string(err_str).decode('utf-8', 'replace'))
RuntimeError: Error opening 'file.ogg': File contains data in an unimplemented format.

请帮帮我。 提前致谢

1 个答案:

答案 0 :(得分:0)

我已经在sungjin han' blog上阅读了此内容,但它可能对golang有所帮助,您可以看到这一部分,他使用了ffmpeg转换器,但它在golang语言上... 他的github

func speechToText(w *witai.Client, fileUrl string) (text string, err error) {
    var oggFilepath, mp3Filepath string
    // download .ogg,
    if oggFilepath, err = downloadFile(fileUrl); err == nil {
        // .ogg => .mp3,
        if mp3Filepath, err = oggToMp3(oggFilepath); err == nil {
            // .mp3 => text
            if result, err := w.QuerySpeechMp3(mp3Filepath, nil, "", "", 1); err == nil {
                log.Printf("> analyzed speech result: %+v\n", result)
                if result.Text != nil {
                    text = fmt.Sprintf("\"%s\"", *result.Text)
                    /*
                        // traverse for more info
                        sessionId := "01234567890abcdef"
                        if results, err := w.ConverseAll(sessionId, *result.Text, nil); err == nil {
                            for i, r := range results {
                                log.Printf("> converse[%d] result: %v\n", i, r)
                            }
                        } else {
                            log.Printf("failed to converse: %s\n", err)
                        }
                    */
                }
            }
            // delete converted file
            if err = os.Remove(mp3Filepath); err != nil {
                log.Printf("*** failed to delete converted file: %s\n", mp3Filepath)
            }
        } else {
            log.Printf("*** failed to convert .ogg to .mp3: %s\n", err)
        }
        // delete downloaded file
        if err = os.Remove(oggFilepath); err != nil {
            log.Printf("*** failed to delete downloaded file: %s\n", oggFilepath)
        }
    }
    return text, err
}