在c#中反序列化以下json响应

本文关键字:json 响应 反序列化 | 更新日期: 2023-09-27 17:59:29

有人能帮我在C#中反序列化以下JSON字符串吗:

{"legend_size": 1, 
"data": {"series": ["2013-02-05", "2013-02-06", "2013-02-07", "2013-02-08", "2013-02-09", "2013-02-10", "2013-02-11", "2013-02-12", "2013-02-13", "2013-02-14"],  "values": 
  {"CampaignHit": {"2013-02-14": 0, "2013-02-13": 0, "2013-02-12": 0, "2013-02-11": 0, "2013-02-10": 0, "2013-02-08": 11, "2013-02-05": 0, "2013-02-07": 14, "2013-02-06": 0, "2013-02-09": 0}}}}

我对CampaignHit部分有问题。我无法反序列化它。

以下是我创建的类:

public class ExportedData
{
    public string legend_size { get; set; }
    public Data data { get; set; }
}
public class Data
{
    public string[] series { get; set; }
    public Values values { get; set; }
}
public class Values
{
    public CampaignHit CampaignHit { get; set; }
}
public class CampaignHit
{
    public CampaignData[] data { get; set; }
}
public class CampaignData
{
    public object first { get; set; }
    public object second { get; set; }
}

以下是反序列化json:的代码

var result = JsonConvert.DeserializeObject<ExportedData>(jsonResponse);

数据部分为null。如何更改CampaignHit类,使数据在反序列化后不为null。

在c#中反序列化以下json响应

使用Newtonsoft.Json:的解决方案

JObject jObject = JObject.Parse(@"{
'legend_size': 1,
'data': {
    'series': [
        '2013-02-05', '2013-02-06', '2013-02-07', '2013-02-08', '2013-02-09', '2013-02-10', '2013-02-11', '2013-02-12', '2013-02-13', '2013-02-14'
    ],
    'values': {
        'CampaignHit': {
            '2013-02-14': 0,
            '2013-02-13': 0,
            '2013-02-12': 0,
            '2013-02-11': 0,
            '2013-02-10': 0,
            '2013-02-08': 11,
            '2013-02-05': 0,
            '2013-02-07': 14,
            '2013-02-06': 0,
            '2013-02-09': 0
        }
    }
}
}");
var  campaignHit = jObject["data"]["values"]["CampaignHit"];
Dictionary<string,int> campaignHitDic = new Dictionary<string,int>();
foreach(JProperty c in campaignHit){
campaignHitDic.Add(c.Name,(int)c.Value);
}