我想解析以下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();