Loading

不规则的JSON解析(一)

现有如下数据结构:

{
  "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>());

 

posted @ 2017-12-26 15:32  guwei4037  阅读(455)  评论(0编辑  收藏  举报