我有一个来自Visistat.com API的Json字符串,我试图用Cson和Json.Net解析。 Json字符串看起来像:
[
["date", "uniques"],
["2014-04-15", "613"],
["2014-04-16", "631"],
["2014-04-17", "593"],
["2014-04-18", "466"],
["2014-04-19", "305"],
["2014-04-20", "294"],
["2014-04-21", "795"],
["2014-04-22", "666"],
["2014-04-23", "625"],
["2014-04-24", "571"],
["2014-04-25", "506"],
["2014-04-26", "342"],
["2014-04-27", "351"],
["2014-04-28", "720"],
["2014-04-29", "606"],
["2014-04-30", "588"],
["2014-05-01", "508"],
["2014-05-02", "545"],
["2014-05-03", "345"],
["2014-05-04", "379"],
["2014-05-05", "833"],
["2014-05-06", "635"],
["2014-05-07", "596"],
["2014-05-08", "530"],
["2014-05-09", "539"],
["2014-05-10", "322"],
["2014-05-11", "290"],
["2014-05-12", "734"],
["2014-05-13", "684"],
["2014-05-14", "555"],
["2014-05-15", "511"]
]
我创建了一个对象,将其反序列化为:
public class DateUnique
{
public DateTime date { get; set; }
public int uniques { get; set; }
}
然后我尝试用以下代码解析Json字符串:
List<DateUnique> dateuniques = JsonConvert.DeserializeObject<List<DateUnique>>(json);
然后我得到了这个例外:
无法将当前JSON数组(例如[1,2,3])反序列化为类型&#39; VisiStatSystem.DateUnique&#39;因为类型需要JSON对象(例如{&#34; name&#34;:&#34; value&#34;})才能正确反序列化。 要修复此错误,请将JSON更改为JSON对象(例如{&#34; name&#34;:&#34; value&#34;})或将反序列化类型更改为实现集合接口的数组或类型(例如ICollection,IList)就像可以从JSON数组反序列化的List。 JsonArrayAttribute也可以添加到类型中以强制它从JSON数组反序列化。 路径&#39; [0]&#39;,第1行,第2位。
我没有在Json.net文档中看到任何示例,它们显示了如何反序列化看起来像VisiStat Api返回的Json字符串。任何帮助表示赞赏!
答案 0 :(得分:1)
您收到此错误是因为您的JSON是一个数组数组,而不是一个对象数组,而您试图将其解析为后者。您需要一些特殊处理才能将其反序列化为List<DateUnique>
。
以下代码应该有效:
JArray array = JArray.Parse(json);
List<DateUnique> list = new List<DateUnique>(array.Count - 1);
for (int i = 1; i < array.Count; i++)
{
list.Add(new DateUnique
{
date = DateTime.ParseExact(array[i][0].ToString(),
"yyyy-MM-dd", System.Globalization.CultureInfo.InvariantCulture),
uniques = int.Parse(array[i][1].ToString())
});
}