在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。
使用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);
}