正确解析 JObject

Parsing JObject properly

我要解析以下json

{
  "status": 1,
  "data": {
  
    "xyz": [
      [
        3.5927680391473826,
        0.5641835941824296,
        -0.88546609584117
      ],
      [
        3.5885032091080853,
        0.7537851201209402,
        -0.9748245317650808
      ]
    ],
    "xy": [
      [
        479,
        32
      ],
      [
        435,
        85
      ]
    ]
  }
}

我正在使用以下代码来执行此操作,

resultantData = JObject.Parse(inputString)
List<float> xyz = resultantData["data"]["xyz"].Value<List<List<float>>>();
List<int> xy = resultantData["data"]["xy"].Value<List<int>>();

不幸的是,上面的代码无法正确解析 JSON。我错过了什么?

你有列表的列表,而不仅仅是列表

List<List<float>> xyz = resultantData["data"]["xyz"].ToObject<List<List<float>>>();
List<List<int>> xy = resultantData["data"]["xy"].ToObject<List<List<int>>>();

你可以这样使用它

if (xyz != null && xyz.Count > 0)
{ 
    List<float> xyz1 = xyz[0];
}

如果你想把所有东西都放在一堆,我认为这不是个好主意,你必须试试这个

List<float> xyz = resultantData["data"]["xyz"].ToObject<List<List<float>>>()
.SelectMany(i=> i).ToList();
List<int> xy = resultantData["data"]["xy"].ToObject<List<List<int>>>()
.SelectMany(i=> i).ToList();

我想你可以使用 JsonConvert.DeserializeObject

var result = JsonConvert.DeserializeObject<Root>(inputString);

public partial class Root
{
    [JsonProperty("status")]
    public long Status { get; set; }

    [JsonProperty("data")]
    public Data Data { get; set; }
}

public partial class Data
{
    [JsonProperty("xyz")]
    public List<List<double>> Xyz { get; set; }

    [JsonProperty("xy")]
    public List<List<long>> Xy { get; set; }
}