首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用System.Speech将mp3文件转换为文本

使用System.Speech将mp3文件转换为文本
EN

Stack Overflow用户
提问于 2013-07-27 08:41:27
回答 2查看 17.5K关注 0票数 9

我试图使用.net中的语音识别来识别mp3文件中播客的语音,并以字符串的形式获得结果。我看到的所有例子都与使用麦克风有关,但我不想使用麦克风并提供一个示例mp3文件作为我的音频源。谁能给我指出任何资源或张贴一个例子。

编辑-

我将音频文件转换为wav文件,并在上面尝试了这段代码。但它只提取了前68个单词。

代码语言:javascript
复制
public class MyRecognizer {
    public string ReadAudio() {
        SpeechRecognitionEngine sre = new SpeechRecognitionEngine();
        Grammar gr = new DictationGrammar();
        sre.LoadGrammar(gr);
        sre.SetInputToWaveFile("C:\\Users\\Soham Dasgupta\\Downloads\\Podcasts\\Engadget_Podcast_353.wav");
        sre.BabbleTimeout = new TimeSpan(Int32.MaxValue);
        sre.InitialSilenceTimeout = new TimeSpan(Int32.MaxValue);
        sre.EndSilenceTimeout = new TimeSpan(100000000);
        sre.EndSilenceTimeoutAmbiguous = new TimeSpan(100000000);
        RecognitionResult result = sre.Recognize(new TimeSpan(Int32.MaxValue));
        return result.Text;
    }
}
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-07-29 09:47:32

试着循环阅读。

代码语言:javascript
复制
SpeechRecognitionEngine sre = new SpeechRecognitionEngine();
Grammar gr = new DictationGrammar();
sre.LoadGrammar(gr);
sre.SetInputToWaveFile("C:\\Users\\Soham Dasgupta\\Downloads\\Podcasts\\Engadget_Podcast_353.wav");
sre.BabbleTimeout = new TimeSpan(Int32.MaxValue);
sre.InitialSilenceTimeout = new TimeSpan(Int32.MaxValue);
sre.EndSilenceTimeout = new TimeSpan(100000000);
sre.EndSilenceTimeoutAmbiguous = new TimeSpan(100000000); 

StringBuilder sb = new StringBuilder();
while (true)
{
    try
    {
        var recText = sre.Recognize();
        if (recText == null)
        {               
            break;
        }

        sb.Append(recText.Text);
    }
    catch (Exception ex)
    {   
        //handle exception      
        //...

        break;
    }
}
return sb.ToString();

如果您有Windows窗体或WPF应用程序,请在单独的线程中运行此代码,否则它将阻塞UI线程。

票数 15
EN

Stack Overflow用户

发布于 2013-07-27 09:51:21

我首先看一下这里记录的方法:http://msdn.microsoft.com/en-us/library/system.speech.recognition.speechrecognitionengine.setinputtowavefile.aspx

我想你应该能从这里解决这个问题。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17895933

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档