如果json包含空数组,则Json.NET SelectTokens无效

时间:2014-11-03 17:00:59

标签: c# .net json.net jsonpath

我有一个有效的JSON对象,其中包含多个" en-US"键,我尝试选择。为此,我使用JsonPath

"$..en-US"

给出了Json.NET实现的SelectTokens过程。它是.NET的JSON框架。只要我的JSON不包含任何空数组,一切都运行正常。 这是一个例子:

var myJsonPath = "$..en-US";
var myJson = 
        @"{
            'controls': [
                {
                    'messages': {
                        'addSuggestion': {
                            'en-US': 'Add'
                        }
                    }
                },
                {
                    'header': {
                        'controls': []
                    },
                    'controls': [
                        {
                            'controls': [
                                {
                                    'defaultCaption': {
                                        'en-US': 'Sort by'
                                    },
                                    'sortOptions': [
                                        {
                                            'label': {
                                                'en-US': 'Name'
                                            }
                                        }
                                    ]
                                }
                            ]
                        }
                    ]
                }
            ]
        }";
var jToken = JObject.Parse(myJson);
var tokens = jToken.SelectTokens(myJsonPath);

此处,令牌变量只包含一个元素!这将是" en-US"在'控件中的空数组之前出现' '标题'宾语。但是,当我离开这个标题时,#39;反对:

var myJson = 
    @"{
        'controls': [
            {
                'messages': {
                    'addSuggestion': {
                        'en-US': 'Add'
                    }
                }
            },
            {
                'controls': [
                    {
                        'controls': [
                            {
                                'defaultCaption': {
                                    'en-US': 'Sort by'
                                },
                                'sortOptions': [
                                    {
                                        'label': {
                                            'en-US': 'Name'
                                        }
                                    }
                                ]
                            }
                        ]
                    }
                ]
            }
        ]
    }";

我将获得" en-US"的所有3个出现的内容。正如所料。顺便说一下,如果我在an online tool中的第一个JSON对象(即包含空数组)上验证我的JsonPath,那么正如预期的那样,我得到所有三个" en-US"案例。这与我从Json.NET获得的内容不同。我想知道这是一个错误还是我必须以某种方式手动处理这个案例?

2 个答案:

答案 0 :(得分:1)

这是一个已修复的错误。升级到最新版本的Json.NET。

答案 1 :(得分:0)

如果您遇到与更新Json.NET版本相关的问题,那么您可以通过以下方式解决问题:

IEnumerable<JValue> vals = jToken
    .Desecendants()
    .Where(w => w is JProperty && w.Name=="en-US")
    .Select(s => s.Value);

希望有所帮助! vals数组将包含您使用之前尝试使用的选择器所使用的相同标记。