我有JSON如下:
{
"request" :
{
"command" : "series",
"series_id" : "PET.WCRSTUS1.W"
},
"series" : [
{
"series_id" : "PET.WCRSTUS1.W",
"name" : "U.S. Ending Stocks of Crude Oil, Weekly",
"units" : "Thousand Barrels",
"f" : "W",
"unitsshort" : "Mbbl",
"description" : "U.S. Ending Stocks of Crude Oil",
"copyright" : "None",
"source" : "EIA, U.S. Energy Information Administration",
"iso3166" : "USA",
"geography" : "USA",
"start" : "19820820",
"end" : "20160715",
"updated" : "2016-07-20T13:18:37-0400",
"data" : [["20160715", 1214561],
["20160708", 1216904],
["20160701", 1219452],
["20160624", 1221677],
["20160617", 1225730],
["20160610", 1226647],
["20160603", 1227580]]
}
]
}
我使用在线JSON转换器生成C#,如下所示:
public class Request
{
public string command { get; set; }
public string series_id { get; set; }
}
public class Series
{
public string series_id { get; set; }
public string name { get; set; }
public string units { get; set; }
public string f { get; set; }
public string unitsshort { get; set; }
public string description { get; set; }
public string copyright { get; set; }
public string source { get; set; }
public string iso3166 { get; set; }
public string geography { get; set; }
public string start { get; set; }
public string end { get; set; }
public string updated { get; set; }
public List<List<Object>> data { get; set; }
}
public class RootObject
{
public Request request { get; set; }
public List<Series> series { get; set; }
}
现在,请注意&#39;数据&#39; &#39;系列&#39;的财产是列表清单。我想做的是创建一个代表这些的类:
public class DataItem
{
public string Date { get; set; }
public int Value { get; set; }
}
然后修改Series类,如下所示:
public class Series
{
public string series_id { get; set; }
public string name { get; set; }
public string units { get; set; }
public string f { get; set; }
public string unitsshort { get; set; }
public string description { get; set; }
public string copyright { get; set; }
public string source { get; set; }
public string iso3166 { get; set; }
public string geography { get; set; }
public string start { get; set; }
public string end { get; set; }
public string updated { get; set; }
public List<DataItem> data { get; set; }
}
当我这样做时,我在data属性中获得了正确的项目数,但每个DataItem都有默认值(空字符串和0表示值)。请有人建议如何(如果)实现这一目标。
我的反序列化是使用System.Runtime.Serialization(而不是Json.Net)。为此,可以认为反序列化例程不受我的控制。不确定这是否相关,但下面是片段:
public static T FromJsonString<T>(string json, Type[] extraTypes = null)
{
T result;
var serializer = new DataContractJsonSerializer(typeof(T), extraTypes ?? new Type[] { });
using (var stream = new MemoryStream())
{
using (var writer = new StreamWriter(stream))
{
writer.Write(json);
writer.Flush();
stream.Position = 0;
result = (T) serializer.ReadObject(stream);
}
}
return result;
}
总结一下:
我正在使用.Net 4.0。
希望这很清楚 - 如果没有,请发表评论。
答案 0 :(得分:1)
如果无法更改传入的json,我认为你必须拥有这两个属性:
public List<List<Object>> Data { get; set; }
public List<DataItem> DataMapped { get; set; }
反序列化到您的数据&#39;属性,然后有一个映射函数,将从data
映射到dataMapped
e.g。
//deserialize here, then...
for (int i = 0; i < Data.Count; i++)
{
DataMapped.Add(new DataItem() { Date = Data[i][0].ToString(), Value = int.Parse(Data[i][1].ToString()) });
}
此处未检查预期值,因此您可能需要添加 - 例如内部列表肯定包含2个对象等...
答案 1 :(得分:0)
如果你特别注意json
Hello this thing is perfect.
数据是一个数组数组,因此您使用的在线生成器已将json正确转换为 "data" : [["20160715", 1214561],
["20160708", 1216904],
["20160701", 1219452],
["20160624", 1221677],
["20160617", 1225730],
["20160610", 1226647],
["20160603", 1227580]]
。
但是,您可以稍后通过迭代public List<List<Object>> data { get; set; }
并为每个内部列表创建public List<DataItem> data { get; set; }
来将此映射到public List<List<Object>> data { get; set; }
。