动态对象列表中的相同列具有字符串和整数

时间:2016-12-25 13:41:08

标签: c# linq json.net

我收到了来自第三方的json doc,当反序列化时有以下格式的动态对象列表

period       key      value
"2013-3"     0   5
"2013-4"     1   6
.
.
.
"2013-10"    5   15
"2013-11"    mykey1   25
"2013-12"    mykey3   6

当我尝试运行linq查询时,我收到错误.. System.FormatException:输入字符串的格式不正确。

如果我只在键列中保留字符串或int值,那就消失了。

真心感谢任何帮助。

linq query ::

示例
data.Where(w => w.key  == "mykey1").Select(s => s.value).ToArray();

示例:http://rextester.com/OMRG78541

1 个答案:

答案 0 :(得分:1)

因为您正在使用动态对象,所以需要强制转换键以验证lambda表达式中的谓词。这是因为即使您使用动态,底层对象也是一个JValue,它不允许字符串和JValue之间的==

data.Where(w => (string)w.key == "mykey1").Select(s => s.value).ToArray(); 

给出示例代码

namespace Rextester
{
    public class Program
    {
        public static void Main(string[] args)
        {
            var json = "[{\"period\":\"2013-3\",\"key\":1,\"val\":18148},{\"period\":\"2013-3\",\"key\":\"totalinteractions\",\"val\":95862},{\"period\":\"2013-3\",\"key\":\"totalusers\",\"val\":160389},{\"period\":\"2013-4\",\"key\":\">10\",\"val\":69915}]";
            var inputdata = JsonConvert.DeserializeObject<IEnumerable<dynamic>>(json);
            var list = inputdata.Where(w => (string)w.key == "totalusers").Select(s => s.val).ToArray();
            foreach (var item in list)
            {
                Console.WriteLine(item);
            }
        }
    }
}

上述输出将导致

160389