现有如下数据结构:
{
"orderId":
"000001"
,
"goodsId[0]"
:
"001"
,
"goodsId[2]"
:
"002"
,
"goodsId[3]"
:
"003"
,
}
goodsId 是无限延伸下去的,问如何解析。
显然,定义类然后解析的思路肯定行不通,即使用dynamic(不需要定义实体类,直接取对应key的值),如: dynamic obj = JsonConvert.DeserializeObject(json); 这样也不行,原因是obj.orderId可以表示,但后面的带有[]的,无法取出。
因此我们必须要换个思路。通过转换为JObject对象的属性Property,获取对应的Value,因此代码如下。
string json = "{"orderId":"000001","goodsId[0]":"001","goodsId[3]":"003","goodsId[10]":"new data"}"; JObject jsonObj = JsonConvert.DeserializeObject(json) as JObject; foreach (var p in jsonObj.Properties().ToArray()) Console.WriteLine("key={0}, value={1}", p.Name, jsonObj[p.Name].Value<string>());