JSON Newtonsoft C#-反序列化JSON文件中的特定字段

时间:2018-09-21 14:59:13

标签: c# json json.net

我正在处理一个巨大的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
}

在此,我预先感谢社区。干杯,

安德烈·卡斯特罗

3 个答案:

答案 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。然后,您可以将特定的子代映射到您的对象。

Reference