获取LUIS的查询结果

时间:2018-08-31 08:32:13

标签: c# json luis azure-cognitive-services

我已经创建了LUIS帐户,并完成了所有需要的工作。

我编写了以下代码,并从LUIS获得了结果。

我需要知道如何将查询结果保存到一个变量中,我想使用该变量来搜索数据库或网络。

下面是代码。

static async void MakeRequest(string qz) {

            var client = new HttpClient();
            var queryString = HttpUtility.ParseQueryString(string.Empty);
            var luisAppId = "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX";
            var endpointKey = "XXXXXXXXXXXX";

            client.DefaultRequestHeaders.Add("Ocp-Apim-Subscription-Key", endpointKey);

            // The "q" parameter contains the utterance to send to LUIS
            queryString["q"] = qz;

            // These optional request parameters are set to their default values
            queryString["timezoneOffset"] = "0";
            queryString["verbose"] = "false";
            queryString["spellCheck"] = "false";
            queryString["staging"] = "false";

            var endpointUri = "https://westus.api.cognitive.microsoft.com/luis/v2.0/apps/" + luisAppId + "?" + queryString;
            var response = await client.GetAsync(endpointUri.);

            var strResponseContent = await response.Content.ReadAsStringAsync();


            // Display the JSON result from LUIS
            Console.WriteLine(strResponseContent.ToString());



        }

这也是查询结果。

{
  "query": "the best resturant in Paris",
  "topScoringIntent": {
    "intent": "city",
    "score": 0.436210483
  },
  "entities": [
    {
      "entity": "paris",
      "type": "city",
      "startIndex": 22,
      "endIndex": 26,
      "score": 0.7153605
    }
  ]
}

现在我要保存此

"entity": "paris",
"type": "city",

为变量。请为我提供指导,因为我是MS LUIS的新手。

示例:

string result =“ paris” ///应该从luis查询中获取值

string type =“ city” ///应该从luis查询中获取值

1 个答案:

答案 0 :(得分:0)

一种选择是将Newtonsoft.Json NuGet包引用到您的项目中。

然后您可以创建两个类(可以随意更改名称)

tmpBox.lstBays.Sort(delegate (SynopticBay x, SynopticBay y)
            {
                return x.szTubeFiberIn.CompareTo(y.szTubeFiberIn);
            });

然后一个使用示例是

public class LuisExtractionLuisResult
{
    public List<LuisEntity> entities { get; set; }
}

public class LuisEntity
{
    public string entity { get; set; }

    public string type { get; set; }
}

然后通过以下方式检索请求的值

var target = JsonConvert.DeserializeObject<LuisExtractionLuisResult>(strResponseContent);

  

还有一个问题,如果在查询中我们有多个实体。   怎么获得呢?

string result = target.entities[0].entity;
string type = target.entities[0].type;