繁体   English   中英

使用Newtonsoft json.net在C#中反序列化JSON对象

[英]Deserialize JSON object in c# using Newtonsoft json.net

我有JSON数组。 我想将此映射/反序列化为以下类。

public sealed class DataItem{
    public string UserId {get; set;}
    public string TestId {get; set;}
    public string UserName{get; set;}
    public string Data1 {get; set;}
    public string Data2 {get; set;}
    public string Data3 {get; set;}
    public string Data4 {get; set;}
    public string Data5 {get; set;}
    public string Data6 {get; set;}
    public string Data7 {get; set;}
    public string Data8 {get; set;}
    public string Data9 {get; set;}
    public string Data10 {get; set;}
    ...
    ...
}

JSON数组:

[{
    "UserId": "5656",
    "TestId": "562",
    "UserName": "testuser",
    "Data1": "dang",
    "Data2": "phy",
    "Data3": "right",
    "Data4": "left",
    "Data5": "top",
    "Data6": "abc",
    "Data7": "rat",
    "Data8": "test",
    "Data9": "91",
    "Data10": "9090",
     ...
     ...
}, {
    "UserId": "8989",
    "TestId": "12",
    "UserName": "abc",
    "Data1": "111",
    "Data2": "222",
    "Data3": "Pwww",
    "Data4": "aaa",
    "Data5": "bbbb",
    "Data6": "cc",
    "Data7": "ooo",
    "Data8": "hh",
    "Data9": "g",
    "Data10": "5656",
     ...
     ...

}]

在我的程序中,我确实是这样的:

IList<DataItem> allItem = JsonConvert.DeserializeObject<IList<DataItem>>(myJsonArray);

这很好。

但是在我的情况下,json数组中大约有1000个数据(如Data1Data1000来自数据库。 而且我不想在我的类“ DataItem ”中定义1000个数据,例如:

public sealed class DataItem{
    ...
    ...
    public string Data1 {get; set;}
    public string Data2 {get; set;}
    .
    .
    .
    public string Data1000 {get; set;}
}

有什么方法可以使用一些动态类或对象来映射这1000个数据(从Data1到Data1000)来解决。

我正在考虑使用1000个长度的数组并像这样映射它们,我知道这将行不通。

 public sealed class DataItem{
   public string UserId {get; set;}
   public string TestId {get; set;}
   public string[] Data {get; set;}
}

public DataItem(){
    Data = new string[1000];
}

在我的程序中:

DataItem dataItem = new DataItem();
IList<DataItem> allItem = JsonConvert.DeserializeObject<IList<DataItem>>(myJsonArray);

PS我不能更改JSON数组的结构。

您可以尝试一些不同的方法:

JObject obj = JObject.Parse(jsonString); // gets processed json object
DataItem item = new DataItem(); 
item.UserId = obj.SelectToken("UserId").Value<string>();
//.. fill rest of the data
string format = "Data{0}";
for(int i = 0; i < item.Data.Length; i++) // iterate through all Data[x]
{
    item.Data[i] = obj.SelectToken(string.Format(format, i)).Value<string>();
}

您可以将其打包到一些类似的方法中:

public DataItem DeserializeFromJson(string json)
{
    // put that code in here
}

编辑:

因此,问题(如您先前所述)是您有一个Json数组。 我的方法只是显示热从数组中读取一个对象。

现在要弄清楚。 如果要反序列化数组,建议使用JsonConvert.DeserializeObject<T>()方法DeserializeFromJson() List<JObject>输入,然后使用我建议您从上面的代码片段中进行JsonConvert.DeserializeObject<T>() DeserializeFromJson()方法。

结合这些,您可以实现以下目标:

public IEnumerable<DataItem> DeserializeListFromJson(string jsonArray)
{
    return JsonConverter.DeserializeObject<List<JObject>>(jsonArray).Select( obj => DeserializeFromJson(obj) );
}

// updated
public DataItem DeserializeFromJson(JObject obj)
{
    DataItem result = new DataItem();
    item.UserId = obj.SelectToken("UserId").Value<string>();
    //.. fill rest of the data
    string format = "Data{0}";
    for(int i = 0; i < item.Data.Length; i++) // iterate through all Data[x]
    {
        item.Data[i] = obj.SelectToken(string.Format(format, i)).Value<string>();
    }
}

您可以使用字典来存储来自JSON字符串的动态属性数量。

以下是将问题中提供的JSON字符串成功转换为字典列表的示例。 除了列表以外,您还可以转换为字典数组。

var jsonData = "[{\"UserId\":\"5656\",\"TestId\":\"562\",\"UserName\":\"testuser\",\"Data1\":\"dang\",\"Data2\":\"phy\",\"Data3\":\"right\",\"Data4\":\"left\",\"Data5\":\"top\",\"Data6\":\"abc\",\"Data7\":\"rat\",\"Data8\":\"test\",\"Data9\":\"91\",\"Data10\":\"9090\"},{\"UserId\":\"8989\",\"TestId\":\"12\",\"UserName\":\"abc\",\"Data1\":\"111\",\"Data2\":\"222\",\"Data3\":\"Pwww\",\"Data4\":\"aaa\",\"Data5\":\"bbbb\",\"Data6\":\"cc\",\"Data7\":\"ooo\",\"Data8\":\"hh\",\"Data9\":\"g\",\"Data10\":\"5656\"}]";

            var data = JsonConvert.DeserializeObject<List<Dictionary<string, string>>>(jsonData);

            Console.WriteLine("Total : {0}", data.Count);
            Console.WriteLine("Item1 Total : {0}", data[0].Count);
            Console.WriteLine("Item2 Total : {0}", data[1].Count);

            foreach(var item in data)
            {
                Console.WriteLine("--- Propertie start-----");
                foreach(var kvPair in item)
                {
                    Console.WriteLine("property name : {0}", kvPair.Key);
                    Console.WriteLine("property value : {0}", kvPair.Value);
                }
                Console.WriteLine("--- Propertie end-----");
            }

            Console.ReadLine();

这样可以解决您的问题。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM