我有一个有效的JSON对象,其中包含一个JSON数组。JSON数组没有花括号,其中包含一个混合类型的逗号分隔列表。它看起来像这样:
{
"ID": 17,
"Days": 979,
"Start_Date": "10/13/2012",
"End_Date": "11/12/2012",
"State": "",
"Page": 1,
"Test": "Valid",
"ROWS": [
[441210, "A", "12/31/2009", "OK", "Done", "KELLEY and Co'", "12/31/2009", "06/29/2010", "TEXAS", "Lawyers", 6, "", "<img src=\"/includes/images/Icon_done.gif\" border=\"0\" alt=\"Done\" title=\"Done\" />"],
[441151, "B", "12/31/2009", "No", "In-process", "Sage & Co", "12/31/2009", "06/29/2010", "CALIFORNIA", "Realtor", 6, "", "<img src=\"/includes/images/Icon_InProcess.gif\" border=\"0\" alt=\"In Process\" title=\"In Process\" />"]
]
}
我创建了一个类来反映JSON结构,其中包含复杂数组的List:
class myModel
{
public int ID { get; set; }
public int Days { get; set; }
public DateTime StartDate { get; set; }
public DateTime EndDate { get; set; }
public string State { get; set; }
public string Page { get; set; }
public string Test { get; set; }
List<ChildModel> Rows { get; set; }
}
我也已经用一个列表的列表进行了测试:
List<List<ChildModel>> Rows { get; set; }
还有这样的子模型:
class ChildModel
{
public int ID { get; set; }
public string StatusId { get; set; }
public DateTime ContactDate { get; set; }
public string State { get; set; }
public string Status { get; set; }
public string CustomerName { get; set; }
public DateTime WorkStartDate { get; set; }
public DateTime WorkEndDate { get; set; }
public string Territory { get; set; }
public string CustType { get; set; }
public int JobOrder { get; set; }
public string Filler { get; set; }
public string Link { get; set; }
}
在我的program.cs文件中,我是这样反序列化的:
using (StreamReader r = new StreamReader(@"D:\01.json"))
{
myModel items = JsonConvert.DeserializeObject<myModel>(r.ReadToEnd());
}
当我运行这个程序时,子对象(Rows)总是
null
。我做错了什么?
ChildModel
被序列化为数组而不是对象?序列化是否超出了您的控制? - 15ee8f99-57ff-4f92-890c-b56153ChildModel
,您可以使用来自 C# JSON.NET - Deserialize response that uses an unusual data structure 的ObjectToArrayConverter<ChildModel>
。 - dbc