如何将字符串转换为QnA Maker返回的JSON

时间:2018-12-14 09:35:58

标签: c# json json.net qnamaker

我目前需要创建一个脚本,该脚本需要通过匹配我在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; }
    }

1 个答案:

答案 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。

如果您随后想要对最终模型进行一些映射,则必须做一个额外的步骤。