我正在使用谷歌语音到文本api将音频文件转换为文本。以下是我的代码(Qt):

   `QString fileName = QDir::currentPath() + "/audio.wav"; //this is my audio file
    QFile audioFile(fileName);
    if(!audioFile.open(QIODevice::ReadOnly | QIODevice::Text)){
        QMessageBox::critical(0,"Error",fileName+" Not found!");
        ui->pushButton_4->setText("Speech to text");
        return;
    }
    int idx = ui->comboBox->currentIndex();
    QString enc;
    if (idx == -1)
        enc = "en-US";
    else
        enc = ui->comboBox->itemData(idx).toString(); //Language selected by user
    QByteArray audioData=audioFile.readAll();
    QUrl url("https://speech.googleapis.com/v1/speech:recognize");
    QUrlQuery query;
    query.addQueryItem("key","myKeyHere...");
    url.setQuery(query);
    QNetworkRequest request(url);
    request.setHeader(QNetworkRequest::ContentTypeHeader,"audio/x-flac");
    QJsonObject json;
    QJsonObject config;
    config["encoding"]="FLAC";
    config["sampleRateHertz"]=44100;
    config["languageCode"]=enc;
    json["config"]=config;
    QJsonObject audio;
    audio["content"]=QString::fromLatin1(audioData.toBase64());
    json["audio"]=audio;
    QByteArray jsonData=QJsonDocument(json).toJson();
    QNetworkAccessManager *manager=new QNetworkAccessManager();
    QNetworkReply *reply=manager->post(request,jsonData);
    QObject::connect(reply,&QNetworkReply::finished,[this,reply](){
        if(reply->error()!=QNetworkReply::NoError){
            QMessageBox::critical(0,"Error Occured",reply->errorString());
            qDebug() << reply->readAll();
            ui->pushButton_4->setText("Speech to text");
            return;
        }
        else if(reply->error()==QNetworkReply::UnknownNetworkError){
            QMessageBox::warning(0,"Network Error","Please check your internet connection and try again!");
            ui->pushButton_4->setText("Speech to text");
        }
        else if(reply->isFinished() && reply->error()==QNetworkReply::NoError){
            QJsonDocument responseJson=QJsonDocument::fromJson(reply->readAll());
            QJsonObject object=responseJson.object();
            QString ResponseText=object["results"].toArray()[0].toObject()
                    ["alternatives"].toArray()[0].toObject()["transcript"].toString();
            QTextCursor cur = curr_browser->textCursor();
            qDebug() << "Response Data :" << ResponseText;
            cur.insertText(ResponseText);
            ui->pushButton_4->setText("Speech to text");
        }
        reply->deleteLater();
    });`

这段代码在Ubuntu上运行得很好,但在windows上却不行。当我在Ubunanuu上运行此程序时,我收到了响应,但在windows上,我收到以下错误:传输错误https://speech.googleapis.com/v1/speech:recognize?key=,myKey>;-服务器答复:请求错误

以下是录制音频文件的代码:

`if (m_audioRecorder->state() == QMediaRecorder::StoppedState) {
      QString fileName = QDir::currentPath() + "/audio.wav";
      m_audioRecorder->setOutputLocation(QUrl::fromLocalFile(fileName));
      qDebug()<<"Recording your audio!!";
      ui->pushButton_4->setText("Stop ?");
      QAudioEncoderSettings settings;
      settings.setCodec("audio/x-flac");
      settings.setSampleRate(0);
      settings.setBitRate(0);
      settings.setChannelCount(1);
      settings.setQuality(QMultimedia::EncodingQuality(2));
      settings.setEncodingMode(QMultimedia::ConstantQualityEncoding);

      m_audioRecorder->setEncodingSettings(settings, QVideoEncoderSettings(), "");
      m_audioRecorder->record();
  }
  else {
      qDebug()<<"stopped your recording!";
      ui->pushButton_4->setText("Processing ...");
      m_audioRecorder->stop();
      speechToTextCall(); //calling the code to send request to google api
  }`

有人能帮忙吗?

我尝试更改编码和容器类型,但在Windows上没有任何效果。

传输时出错https://speech.googleapis.com/v1/speech:recognize?key=,myKey>;-服务器回答:错误请求[Windows操作系统上的问题]的更多相关文章

  1. QT与javascript交互数据的实现

    本文主要介绍了QT与javascript交互数据的实现,主要包括数据从QT流向JS以及数据从JS流向QT的几种方法,需要的朋友们下面随着小编来一起学习学习吧

  2. Qt创建者CDB无法进入

    Qt5.12.2适用于msvc2017,QtCreator9.0.1,已安装VisualStudio2019。对于虚拟方法和std,我进入了一个无法正常工作的特性,例如:我在smartObject->virtualMethod()行,按F11获取QScopedPointer的源文件:我按shift+F11并再次到达第smartObject->virtualMethod()行,然后再按F11并到达下一行,而不是进入virtualMethod()体。

  3. 如何在PyQt5中删除QTableView中聚焦项周围的虚线框

    我正在编写一个简单的PyQt5应用程序,它使用QTableView小部件。我要做的是删除QTableView中聚焦项周围的虚线框。如果这很重要,我在Windows计算机上使用PyQt5==5.15.4,PyQt5-Qt5==5.15.2。

  4. 面临pyqt6问题。尝试用它创建一个基本的记事本

    这是我的view.py文件的代码,我现在正面临问题。

  5. 为什么QThread的任务在函数返回之前无法执行

    事实上,可能不需要创建一个新任务并等待它执行,因为既然你必须等待并陷入其中,为什么不直接在函数中运行它呢。但当我处理QT串行数据时,这实际上是一个问题。有没有办法处理串行数据发送和接收同步?

  6. 传输时出错https://speech.googleapis.com/v1/speech:recognize?key=,myKey&gt;-服务器回答:错误请求[Windows操作系统上的问题]

    我正在使用谷歌语音到文本api将音频文件转换为文本。当我在Ubunanuu上运行此程序时,我收到了响应,但在windows上,我收到以下错误:传输错误https://speech.googleapis.com/v1/speech:recognize?key=,myKey>;-服务器答复:请求错误以下是录制音频文件的代码:有人能帮忙吗?我尝试更改编码和容器类型,但在Windows上没有任何效果。

  7. Qt-如何延迟对QAbstractItemModel::data()的调用

    https://doc.qt.io/qt-6/qabstractitemmodel.html#data如果我的数据访问延迟很高,我如何告诉Qt稍后再次调用QAbstractItemModel::data()?

  8. 获取RTSP播放的帧时间戳

    我正在使用gstreamer在qt上制作简单的相机播放视频播放器,可以从OSD中获取帧日期/时间还是仅获取时间?图片上的时间戳的例子,目前与hikvision合作,试图在用wireshark转储的RTP数据包上找到它,但它只与第一帧时间戳相关。

  9. 使用Qt QSS绘制简单美化界面功能

    这篇文章主要介绍了使用Qt QSS绘制简单美化界面,本文以绘制登录界面为例,创建一个继承自Qwidget的设计师界面类,为了使得控件排放整齐有序,可以使用layout布局进行辅助,感兴趣的朋友跟随小编一起看看吧

随机推荐

  1. 如何扩展ATmega324PB微控制器的以下宏寄存器?

    我目前正在学习嵌入式,我有以下练习:展开以下宏寄存器:如果有人解决了这个问题,我将不胜感激,以便将来参考

  2. Python将ONNX运行时设置为返回张量而不是numpy数组

    在python中,我正在加载预定义的模型:然后我加载一些数据并运行它:到目前为止,它仍在正常工作,但我希望它默认返回Tensor列表,而不是numpy数组。我对ONNX和PyTorch都是新手,我觉得这是我在这里缺少的基本内容。这将使转换中的一些开销相同。

  3. 在macOS上的终端中使用Shell查找文件中的单词

    我有一个文本文件,其中有一行:我需要找到ID并将其提取到变量中。我想出了一个RexEx模式:但它似乎对我尝试过的任何东西都不起作用:grep、sed——不管怎样。我的一个尝试是:我为这样一个看似愚蠢的问题感到抱歉,但我在互联网上找不到任何东西:我在SO和SE上读了几十个类似的问题,并在谷歌上搜索了几个教程,但仍然无法找到答案。欢迎提供任何指导!

  4. react-chartjs-2甜甜圈图中只有标题未更新

    我正在使用react-chartjs-2在我的网站中实现甜甜圈图。下面是我用来呈现图表的代码。我将甜甜圈图的详细信息从父组件传递到子组件,所有道具都正确传递。当我在beforeDraw函数外部记录props.title时,它会记录正确的值,但当我在beforeDraw函数内部记录props.title时,它将记录标题的前一个值,从而呈现标题的前值。我在这里做错了什么?

  5. 如何在tkinter中使用Python生成器函数?

    生成器函数承诺使某些代码更易于编写。但我并不总是知道如何使用它们。假设我有一个斐波那契生成器函数fib(),我想要一个显示第一个结果的tkinter应用程序。当我点击“下一步”按钮时,它会显示第二个数字,依此类推。我如何构建应用程序来实现这一点?我可能需要在线程中运行生成器。但如何将其连接回GUI?

  6. 如何为每次提交将存储库历史记录拆分为一行?

    我正在尝试获取存储库的历史记录,但结果仅以单行文本的形式返回给我。

  7. 尝试在颤振项目上初始化Firebase时出错

    当尝试在我的颤振项目上初始化firebase时,我收到了这个错误有人知道我能做什么吗?应用程序分级Gradle插件Gradle项目颤振相关性我已经将firebase设置为Google文档已经在另一个模拟器上尝试过,已经尝试过创建一个全新的模拟器,已经在不同的设备上尝试过了,已经尝试了特定版本的firebase,已经尝试添加但没有任何效果,已经在youtube上看到了关于它的每一个视频,该应用程序在android和iOS两个平台上都抛出了这个错误

  8. 在unix中基于当前日期添加新列

    我试图在unix中基于时间戳列在最后一个单元格中添加一个状态列。我不确定如何继续。

  9. 麦克斯·蒙特利。我一直得到UncaughtReferenceError:当我在终端中写入node-v时,节点未定义

    如果这是您应该知道的,请确认:我已将所有shell更改为默认为zsh。当我在终端中写入node-v时,我一直收到“UncaughtReferenceError:nodeisnotdefined”。但它显示节点已安装。我是个新手,在这方面经验不足。

  10. 如何在前端单击按钮时调用后端中的函数?

    那么如何在后端添加一个新的端点,点击按钮调用这个函数。

返回
顶部