我有一个包含 Json 数据的 JObject 对象。我需要收集所有具有"state": true
. 在读取值之前,我想确保 JObject 至少有一个 KeyValuePairs 且 JToken (Value) has "state": true
。
下面是我的 JSON:
{
"AAA": {
"state": false,
"version": "1.1.14202.0",
"result": null,
"update": "20171018"
},
"BBB": {
"state": true,
"version": "3.10.1.18987",
"result": null,
"update": "20171018"
},
"CCC": {
"state": true,
"version": "1.1.1.2",
"result": null,
"update": "20171018"
}
}
Run Code Online (Sandbox Code Playgroud)
下面是我当前正在检查的代码,它抛出一个异常Cannot access child value on Newtonsoft.Json.Linq.JProperty
:
JObject jsonData = //JSON data;
List<JToken> tokens = jsonData .Children().ToList();
if (tokens.Any(each => each["state"].ToString().ToLower().Contains("true")))
{
List<JToken> tokensWithStateTrue = tokens.Where(each => each["state"].ToString().ToLower().Contains("true")).ToList();
}
Run Code Online (Sandbox Code Playgroud)
请帮助我并更正 LinQ 语句,使其仅读取状态为true 的JToken 。
这对我有用,看起来您缺少对 Children() 的额外调用来访问您需要的属性。
//parse JSON and grab it's children.
var jsonData = JObject.Parse(json).Children();
List<JToken> tokens = jsonData .Children().ToList();
Run Code Online (Sandbox Code Playgroud)
或者
List<JToken> tokens = jsonData .Children().Children().ToList();
if (tokens.Any(each => each["state"].ToString().ToLower().Contains("true")))
{
List<JToken> tokensWithStateTrue = tokens.Where(each => each["state"].ToString().ToLower().Contains("true")).ToList();
}
Run Code Online (Sandbox Code Playgroud)
或者你也可以这样做。下面的代码将返回一个字典,其中仅包含具有真实值的状态。否则,如果没有真值,它将返回一个空字典。
var dictionaryTokensWithTrueValues = jsonData.Children()
.Select(u => u as JProperty)
.Where(v => v.Value["state"].ToString().ToLower().Contains("true"))
.ToDictionary(k => k.Name, v => v.Value);
//check if you have any true values
if (dictionaryTokensWithTrueValues.Count() > 0)
{
//do something with true states here
var accessBBB = dictionaryTokensWithTrueValues["BBB"]; //{{"state": true,"version": "3.10.1.18987","result": null,"update": "20171018"}}
}
else
{
//no true states. Do something else
}
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
41922 次 |
最近记录: |