gpt4 book ai didi

microsoft-cognitive - 显示 QnAMaker 后续提示的文本

转载 作者:行者123 更新时间:2023-12-04 02:43:31 24 4
gpt4 key购买 nike

我正在尝试在 QnAMaker 中使用后续提示,但对“后续提示”创建对话框中标记为“显示文本”的字段的用途感到困惑。 https://learn.microsoft.com/en-us/azure/cognitive-services/qnamaker/how-to/multiturn-conversation将此字段描述为“要在后续提示中显示的自定义文本。”。对我来说,这表明它只是后续提示的标签,通常呈现为按钮。因此,我假设该文本除了作为标签外没有其他用途,并且该按钮将直接链接到所选的问题/答案对。然而,从 QnAMaker 知识库的实验来看,“显示文本”似乎实际上已传递给 QnAMaker 服务,并且该文本用于搜索答案。这意味着必须选择“显示文本”值,以便标记按钮和成功找到后续答案。

这意味着我不能使用简短的后续提示,例如“我该如何付款?”或“我如何加入它?”其中主要的 Q/A 对与各种服务之一相关,因为这些字符串不会可靠地返回预期的答案。相反,提示必须是更详细的“我如何为服务 A 付费”和“我如何加入服务 A”。

我的理解正确吗?我认为文档根本没有说明这一点......

最佳答案

多轮 QnA Maker 对话仍处于预览阶段,目前没有可帮助您构建知道如何与后续提示 API 交互的机器人的 SDK。您最终处于控制之中,因此您可以让您的机器人随心所欲地处理显示文本。所有“显示文本”都是您插入到知识库答案中的值,以便在调用 generateAnswer 后它与答案一起返回。

让您的显示文本与您链接到的问题的文本相匹配会非常有帮助,因为这样提示的显示文本就可以用于访问正确的后续 QnA 对,只要包含上下文在 API 调用中。这就是 this sample 中发生的事情.听起来您想在提示的显示文本不与后续问题的文本匹配的情况下让它工作。这可能会变得棘手,但您可以做一些事情。

请记住,在进行后续提示时,您指定的不仅仅是显示文本。您还链接到特定的 QnA 对。这允许 API 将该 QnA ID 与显示文本一起返回给您。您没有提到您的机器人针对哪个 channel ,但是如果您使用的 channel 支持 postBackmessageBack 操作,那么您可以将 QnA ID 传递给您的机器人无形地然后你的机器人可以使用它来访问答案。如果你走这条路,你甚至不需要担心对话框或状态。您还没有提到您使用什么语言编写机器人,但这里有一个如何在 Node.js 中实现的示例:

async testQnAMaker(turnContext) {
var qna = new QnAMaker({
knowledgeBaseId: '<GUID>',
endpointKey: '<GUID>',
host: 'https://<APPNAME>.azurewebsites.net/qnamaker'
});

var value = turnContext.activity.value;
var qnaId = value && value.qnaId;
// qnaId will be undefined if value is empty
var results = await qna.getAnswers(turnContext, { qnaId });
var firstResult = results[0];

if (firstResult) {
var answer = firstResult.answer;
var resultContext = firstResult.context;
var prompts = resultContext && resultContext.prompts;

if (prompts && prompts.length) {
var card = CardFactory.heroCard(
answer,
[],
prompts.map(prompt => ({
type: 'messageBack',
title: prompt.displayText,
displayText: prompt.displayText,
text: prompt.displayText,
value: { qnaId: prompt.qnaId }
}))
);

answer = MessageFactory.attachment(card);
}

await turnContext.sendActivity(answer);
} else {
await turnContext.sendActivity("I can't answer that");
}
}

请注意,这确实有一些限制。因为它通过从事件的值属性中检索 QnA ID 来工作,所以如果用户手动键入按钮的文本而不是单击按钮,它可能无法找到正确的 QnA 对。

如果您想让显示文本独立工作而不依赖于 QnA ID,您可以保存自己的映射,以便您的机器人知道在每个上下文中哪些显示文本值对应于每个 QnA ID。但是,您也可以考虑只添加显示文本作为 QnA 对中问题的替代措辞。因此,“我如何为服务 A 付款”和“我如何为服务 B 付款”都可以将“我如何为它付款”作为问题的一种形式。因为您现在在多个 QnA 对中有重复的措辞,所以您需要在调用 generateAnswer 时传递上下文,这样才能正常工作。

参见 this answer有关多轮对话的更多信息。

关于microsoft-cognitive - 显示 QnAMaker 后续提示的文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58203069/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com