如何使用Json.net解析Visistat API的Json输出

时间:2014-05-16 02:06:45

标签: c# json json.net

我有一个来自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字符串。任何帮助表示赞赏!

1 个答案:

答案 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())
    });
}