小编3-p*_*utt的帖子

在 App Insights for QnA Maker 中寻找唯一的“对话 ID”

我们正在使用连接到Azure 机器人服务的QnA Maker。在知识库 (KB) 中,我们为每个问题添加了一个跟进提示This did NOT answer my question

知识库 > 跟进提示

这意味着如果提供了错误的响应,最终用户可以指出,对话历史将如下所示:

示例对话

我们要做的是重播对话历史,以便我们可以看到:

  1. 原始用户提示
  2. 原来的答案
  3. 后续后续问题/答案

我们打开了Application Insights,因此我们可以通过以下查询从日志中看到这两个问题:

traces
| project timestamp, 
          itemId,
          question = customDimensions.Question,
          answer = customDimensions.Answer
| order by timestamp
Run Code Online (Sandbox Code Playgroud)

这将返回这两行:

应用洞察日志

但是,我们正在尝试找到可以关联这两个记录的唯一对话 ID 或会话 ID。请注意,itemId非常相似,但不完全相同:

53be8c14-702c-11ea-8c41-11c1c266dc55
53be8c13-702c-11ea-8c41-11c1c266dc55
Run Code Online (Sandbox Code Playgroud)

是否有唯一的密钥可以用于加入这两个事件?

一种解决方法是仅使用 的前 7 位数字itemID并基于该部分匹配进行连接,如下所示:

traces
| where customDimensions.Question contains "This did NOT answer my question" 
| project itemId,
          SessionID = extract("^[a-z0-9]{7}", 0, itemId),
          timestamp …
Run Code Online (Sandbox Code Playgroud)

azure-application-insights botframework azure-qna-maker kql

6
推荐指数
1
解决办法
345
查看次数