使用 JSON.net 解析 InfluxDB 结果

瑞恩·里奇

我正在尝试制作一个用于初始化 InfluxDB 数据库的命令行实用程序,但我对 influx 和 C# 还很陌生。

通过来自 Influx DB 数据库的以下响应,我试图在控制台窗口中漂亮地打印出来。

理想情况下,我会在标准错误缓冲区中显示错误,并在标准输出中显示警告或信息。

但是,在调试环境中运行下面的代码时,根据我使用的几个 jsonpath 检查器,消息的格式似乎不正确。

JSON 输入作为 result.Body

{
  "results": [
    {
      "statement_id": 0,
      "messages": [
        {
          "level": "warning",
          "text": "deprecated use of 'CREATE RETENTION POLICY Primary ON SensorData DURATION 30d REPLICATION 1' in a read only context, please use a POST request instead"
        }
      ]
    }
  ]
}

JSON 输出作为转换前的消息:

messages    {{
  "level": "warning",
  "text": "deprecated use of 'CREATE RETENTION POLICY Primary ON SensorData DURATION 30d REPLICATION 1' in a read only context, please use a POST request instead"
}}  Newtonsoft.Json.Linq.JToken {Newtonsoft.Json.Linq.JObject}

如您所见,消息输出位于嵌套对象 {{}} 中,而不是如预期的数组...

根据https://jsonpath.curiousconcept.com/和其他几个 jsonpath 检查器,我期待类似于:

[
   {
      "level":"warning",
      "text":"deprecated use of 'CREATE RETENTION POLICY Primary ON SensorData DURATION 30d REPLICATION 1' in a read only context, please use a POST request instead"
   }
]

C#

    private static void PrintResult(IInfluxDataApiResponse result)
    {
        var output = result.Success ? System.Console.Out : System.Console.Error;
        output.WriteLine("["+result.StatusCode + "] : "+result.Body);
        var json = JObject.Parse(result.Body);
        var messages = json.SelectToken("$.results[*].messages[*]"); //outputs an array of messages if exists. e.g. [{level:warning,text:test}]
        if (messages != null)
        {
            var transformed = messages.Select(m => new { level = (string)m["level"], text = (string)m["text]"] }).ToList();
            foreach (var msg in transformed)
            {
                output.WriteLine($"[{result.StatusCode}] : {msg.level} - {msg.text}");
            }
        }

    }
瑞恩·里奇

至少对于我的用途,使用 var 消息 =

json.SelectTokens("$.results[*].messages[*]"); 

而不是

json.SelectToken("$.results[*].messages[*]"); 

允许我解决这个问题,因为我可以将结果视为 C# 可枚举的,而不是特殊的大小写 1 结果与 SelectToken 的许多结果,因为它似乎将单个结果展平到一个对象中,而其他实现会这样数组。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章