我正在处理一个巨大的JSON文件,只需在其中提取其中的某些字段即可。我一直在寻找一些反序列化的方法,但是不想在C#中使用JSON内的所有字段创建整个类和对象,这会浪费很多内存。
我可以使用Webclient获取JSON文件:
using (WebClient wc = new WebClient())
{
jsonWeb = wc.DownloadString("http://link_to_get_JSON");
}
//Deserialize into a JObject
JObject obj = JObject.Parse(jsonWeb);
//Tried to access the info with
var val = obj.PropTwo;
var solution = obj.Descendants().OfType<JProperty>().Where(p => p.Name == "solverSolution").Select(x => x.Value.ToString()).ToArray();
我真的找不到在 JObject 中获取所需字段的方法。 在JSON中,唯一需要的信息是下面的 solverSolution:{} :
{
"content":
[
{
"id":"f4d7e7f5-86ab-4155-8336-ca5f552cb3b4",
"name":"m1",
"description":"m1",
"maxHeight":2000.0,
"layers":6,
"pallet":{},
"product":{},
"solverSolution":
{
"id":"106ef605-d95e-4c74-851b-63310fbcbc7d",
"name":"solver",
"maxHeight":2000.0,
"layers":6,
"solution":[
{
"X1":0,
"Y1":0,
"Z1":0,
"X2":296,
"Y2":246,
"Z2":220
},
...
"default":false
},
"customSolutions":[0]
},
{},
...
],
"pageable":{},
"totalPages":1,
"last":true,
"totalElements":7,
"first":true,
"sort":{},
"number":0,
"numberOfElements":7,
"size":20
}
在此,我预先感谢社区。干杯,
安德烈·卡斯特罗
答案 0 :(得分:5)
然后仅在对象中使用所需的属性,并确保遵循所需模型的结构。
public partial class RootObject {
[JsonProperty("content")]
public Content[] Content { get; set; }
}
public partial class Content {
[JsonProperty("solverSolution")]
public SolverSolution SolverSolution { get; set; }
}
public partial class SolverSolution {
[JsonProperty("id")]
public Guid Id { get; set; }
[JsonProperty("name")]
public string Name { get; set; }
[JsonProperty("maxHeight")]
public double MaxHeight { get; set; }
[JsonProperty("layers")]
public long Layers { get; set; }
[JsonProperty("solution")]
public Solution[] Solution { get; set; }
[JsonProperty("default")]
public bool Default { get; set; }
}
public partial class Solution {
[JsonProperty("X1")]
public long X1 { get; set; }
[JsonProperty("Y1")]
public long Y1 { get; set; }
[JsonProperty("Z1")]
public long Z1 { get; set; }
[JsonProperty("X2")]
public long X2 { get; set; }
[JsonProperty("Y2")]
public long Y2 { get; set; }
[JsonProperty("Z2")]
public long Z2 { get; set; }
}
解析器将忽略未映射到对象模型属性的其余部分。
var root = Jsonsonvert.DeserializeObject<RootObject>(jsonWeb);
var solverSolution = root.Content[0].SolverSolution;
我如何获得所有SolverSolution
SolverSolution[] solutions = root.Content.Select(content => content.SolverSolution).ToArray();
答案 1 :(得分:1)
我使用:
JsonConvert.DeserializeObject<dynamic>(stringInput)
获取我需要的匿名类型
然后,您可以使用类似的方法来获取特定的部分:
var obj = JsonConvert.DeserializeObject<dynamic>(input)["content"][0]["solverSolution"];
这很容易,可以帮我完成工作。
编辑: 旁注,请下次在上载json时,只剪掉不需要的部分,以便我可以对其进行序列化,花了一些时间来修复它:D
答案 2 :(得分:0)
您可以使用JObject解析所有Json。然后,您可以将特定的子代映射到您的对象。