从动态json结果中获取列表

时间:2013-09-16 11:45:48

标签: c# json linq json.net

使用

dynamic result = JsonConvert.DeserializeObject(jsonResult);

我得到以下Json

{
 facet_counts: {
  facet_queries: { },
   facet_fields: {
     Suggest: [
      "AAA",
      0,
      "BBB",
      0,
      "CCC",
      0,
      "DDD",
      0,
      "EEE",
      0]
},

我想迭代“建议”获取赔率位置(1,3,5 ..)的值列表 即“AAA”,“BBB”,“CCC”,“DDD”

我可以使用基本的

来获取它们
dynamic resultList = result.facet_counts.facet_fields.Suggest.Children();
foreach (dynamic child in resultList)
{
   strings.Add(child.ToString());
}

但由于所有的动态字段都是JVAlue,我必须使用索引并添加条件,我想知道是否有更优雅的方式(也许是linq?)。
感谢。

2 个答案:

答案 0 :(得分:4)

使用来自Linque的以下内容。

resultList.Where((child, index) => (index) %2!=0); 

我希望它会对你有所帮助。

答案 1 :(得分:1)

反序列化JSON的一种方法是使用 Newtonsoft (而不是循环);

List<string> myList = Newtonsoft.Json.JsonConvert.DeserializeObject<List<string>>(resultList);

然后我简单的linq,你可以过滤你的数据。