我目前需要创建一个脚本,该脚本需要通过匹配我在excel文件中存在的问题来更新QnA Maker中qna对的元数据。我目前正在遵循REST API指南:
https://docs.microsoft.com/en-us/azure/cognitive-services/qnamaker/quickstarts/csharp
我已经从QnA Maker中检索了qna对,但是由于它返回了所有qna信息的字符串值,因此我需要将其转换为JSON,并将其与从excel文件中检索到的QnA对象列表进行匹配。
public async static Task<string> GetQnAFromQnAMaker()
{
string getmethod = "/knowledgebases/{0}/{1}/qna/";
var method_with_id = String.Format(getmethod, kbid, env);
var uri = host + service + method_with_id;
Console.WriteLine("Calling " + uri + ".");
var response = await Get(uri);
return response;
}
我使用了NewtonSoft反序列化对象
List<FAQs> qnaMakerFaq = JsonConvert.DeserializeObject<List<FAQs>>(qnaFromQnAMaker.Result);
但是我得到这个错误:
Newtonsoft.Json.JsonSerializationException:'无法反序列化 当前的JSON对象(例如{“ name”:“ value”}) 'System.Collections.Generic.List`1 [ExcelToQnAMaker.FAQs]',因为 类型需要JSON数组(例如[1,2,3])才能正确反序列化。至 修复此错误,或者将JSON更改为JSON数组(例如[1,2,3]) 或更改反序列化类型,使其成为普通的.NET类型(例如 不是像整数这样的原始类型,不是像数组这样的集合类型 或列表),可以从JSON对象反序列化。 还可以将JsonObjectAttribute添加到类型中以强制其 从JSON对象反序列化。路径'qnaDocuments',第2行,位置 17。'
我返回的结果字符串看起来像这样...
“ {\ r \ n \” qnaDocuments \“:[\ r \ n {\ r \ n \” id \“:....
这是我的常见问题解答课程
public class FAQs
{
public List<string> Questions { get; set; }
public string Answers { get; set; }
public string Classification { get; set; }
public string Division { get; set; }
public int Spid { get; set; }
public int Kbid { get; set; }
}
答案 0 :(得分:1)
如果您查看Download Knowledgebase的API文档,则收到的响应应该像
{
"qnaDocuments": [
{
"id": 1,
"answer": "You can change the default message if you use the QnAMakerDialog. See this for details: https://docs.botframework.com/en-us/azure-bot-service/templates/qnamaker/#navtitle",
"source": "Custom Editorial",
"questions": [
"How can I change the default message from QnA Maker?"
],
"metadata": []
},
{
"id": 2,
"answer": "You can use our REST apis to manage your KB. See here for details: https://westus.dev.cognitive.microsoft.com/docs/services/58994a073d9e04097c7ba6fe/operations/58994a073d9e041ad42d9baa",
"source": "Custom Editorial",
"questions": [
"How do I programmatically update my KB?"
],
"metadata": [
{
"name": "category",
"value": "api"
}
]
}
]
}
您要反序列化的模型应与此结构匹配...
public class KnowledgebaseResponse
{
public List<KnowledgebaseItem> QnaDocuments { get; set; }
}
public class KnowledgebaseItem
{
public int Id { get; set; }
public string Answer { get; set; }
public string Source { get; set; }
public List<string> Questions { get; set; }
public List<KeyValuePair<string, string>> MetaData { get; set; }
}
然后您可以正确地反序列化JSON。
如果您随后想要对最终模型进行一些映射,则必须做一个额外的步骤。