首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >动态对象列表中的同一列具有字符串和整数。

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

Stack Overflow用户
提问于 2016-12-25 13:41:08
回答 1查看 43关注 0票数 0

我从第三方收到了一个json,当反序列化时它有一个动态对象列表,格式如下

代码语言:javascript
复制
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查询::

代码语言:javascript
复制
data.Where(w => w.key  == "mykey1").Select(s => s.value).ToArray();

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

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-12-25 14:34:42

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

代码语言:javascript
复制
data.Where(w => (string)w.key == "mykey1").Select(s => s.value).ToArray(); 

给定示例代码

代码语言:javascript
复制
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);
            }
        }
    }
}

以上的输出将导致

代码语言:javascript
复制
160389
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41321593

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档