Node.js app.js有时返回TypeError:无法读取属性';0';关于完整问题的未定义

Node.js app.js有时返回TypeError:无法读取属性';0';关于完整问题的未定义,node.js,botframework,azure-language-understanding,azure-bot-service,qnamaker,Node.js,Botframework,Azure Language Understanding,Azure Bot Service,Qnamaker,我正在使用Microsoft代码示例尝试创建一个LUIS机器人,它使用意图触发QNA生成器 此时,QnA生成器有时返回结果,但有时返回“TypeError:无法读取未定义的属性“0” 带有以下代码的问题“价格变化”返回QnA制造商的正确答案 var customQnAMakerTools = new customQnAMakerTools.CustomQnAMakerTools(); bot.library(customQnAMakerTools.createLibrary()); var

我正在使用Microsoft代码示例尝试创建一个LUIS机器人,它使用意图触发QNA生成器

此时,QnA生成器有时返回结果,但有时返回“TypeError:无法读取未定义的属性“0”

带有以下代码的问题“价格变化”返回QnA制造商的正确答案

var customQnAMakerTools = new customQnAMakerTools.CustomQnAMakerTools();
bot.library(customQnAMakerTools.createLibrary());


var intents = new builder.IntentDialog({ recognizers: [recognizer, 
r12recognizer] });
bot.dialog('/', intents);

var basicQnAMakerDialog = new builder_cognitiveservices.QnAMakerDialog({
    recognizers: [r12recognizer],
    defaultMessage: 'Sorry i did not understand that. Try asking the 
question again.',
    qnaThreshold: 0.3,
    feedbackLib: customQnAMakerTools
});

intents.matches('qna', [
basicQnAMakerDialog.respondFromQnAMakerResult = function(session, 
qnaMakerResult){
// Save the question
var question = session.message.text;
session.conversationData.userQuestion = question;
// boolean to check if the result is formatted for a card


var isCardFormat = qnaMakerResult.answers[0].answer.includes(';');
if(!isCardFormat){
    // Not semi colon delimited, send a normal text response 
    session.send(qnaMakerResult.answers[0].answer);
}else if(qnaMakerResult.answers && qnaMakerResult.score >= 0.5){

    var qnaAnswer = qnaMakerResult.answers[0].answer;
            var qnaAnswerData = qnaAnswer.split(';');
            var title = qnaAnswerData[0];
            var description = qnaAnswerData[1];
            var url = qnaAnswerData[2];
            var imageURL = qnaAnswerData[3];

            var msg = new builder.Message(session)
            msg.attachments([
                new builder.HeroCard(session)
                .title(title)
                .subtitle(description)
                .images([builder.CardImage.create(session, imageURL)])
                .buttons([
                    builder.CardAction.openUrl(session, url, "Learn More")
                ])
            ]);
    }
session.send(msg).endDialog();
}


]);
但是,如果我将问题更改为“价格变更已批准,但最终被系统拒绝”,这是QnA Maker中的完整问题,它将返回“TypeError:无法读取未定义的属性“0”。完全错误是

TypeError: Cannot read property '0' of undefined
    at Array.intents.matches.basicQnAMakerDialog.respondFromQnAMakerResult (D:\home\site\wwwroot\app.js:71:46)
    at Object.waterfallHandler [as qna] (D:\home\site\wwwroot\node_modules\botbuilder\lib\dialogs\WaterfallDialog.js:139:29)
    at IntentDialog.invokeIntent (D:\home\site\wwwroot\node_modules\botbuilder\lib\dialogs\IntentDialog.js:163:44)
    at D:\home\site\wwwroot\node_modules\botbuilder\lib\dialogs\IntentDialog.js:71:27
    at next (D:\home\site\wwwroot\node_modules\botbuilder\lib\dialogs\IntentRecognizer.js:68:17)
    at IntentRecognizerSet.IntentRecognizer.filter (D:\home\site\wwwroot\node_modules\botbuilder\lib\dialogs\IntentRecognizer.js:71:9)
    at D:\home\site\wwwroot\node_modules\botbuilder\lib\dialogs\IntentRecognizer.js:20:31
    at D:\home\site\wwwroot\node_modules\botbuilder\lib\dialogs\IntentRecognizerSet.js:80:17
    at D:\home\site\wwwroot\node_modules\async\lib\async.js:52:16
    at replenish (D:\home\site\wwwroot\node_modules\async\lib\async.js:306:28)

如果是因为我不正确地传递了问题,或者只是传递了问题的一部分,我目前无法进行训练。

如果你对路易斯有相同的意图,这似乎会发生。一旦意图被删除,QnA意图将正确启动并将消息发送到QnA知识库。

看起来像是QnaMaker没有回复的情况,因此
qnaMakerResult.answers[0]
抛出异常,因为
answers
未定义?您是否直接查看过您的QnA,以测试您传递的值?当我在测试区域和作为机器人服务向QnA制造商提问时,它只在路易斯意图内传递正确答案,并抛出“价格变化已批准,但最终被系统拒绝”是qna知识库中qna对的实际完整问题。您的两个案例的回答是否相同?是的,两个案例都应返回相同的回答OK。。抱歉,没有QnA数据就帮不上什么忙了。我们刚刚尝试了这个方法,它似乎可以工作,不知道为什么。非常感谢。这也使得在仍然使用LUIS的情况下,可以从多个知识库中获取答案