正确解析jobobject



我想解析以下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。我错过了什么?

我认为你可以使用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; }
}

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

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();

相关内容

  • 没有找到相关文章