Newtonsoft.JSON 的 JsonPath
JsonPath with Newtonsoft.JSON
我尝试了将近一个小时的不同方法,但我不明白;(
我的JSON对象是这样的:
"typeOfHair": {
"value": [
{
"code": "Dry Hair",
"values": [
{
"value": "DryHair",
"language": "en"
},
{
"value": "TrockenesHaar",
"language": "de"
}
]
},
{
"code": "Any Type of Hair",
"values": [
{
"value": "AnyTypeOfHair",
"language": "en"
},
{
"value": "JedenHaartyp",
"language": "de"
}
]
}
]
}
我的任务是使用 Newtonsoft.JSON 获取语言为 "de" 的所有值。
我目前的做法是:
JsonObject.SelectTokens("typeOfHair.value.values[?(@.language == 'de')].value").ToList()
有人可以帮我解决这个问题吗?
亲切的问候
你非常接近。您需要使用 JsonPATH 通配符 [*]
:
来计算外部 value
数组 typeOfHair.value[]
var values = JsonObject.SelectTokens("typeOfHair.value[*].values[?(@.language == 'de')].value")
// Convert from JValue to string
.Select(v => (string)v)
// Save in a list
.ToList();
并且,结果是:
["TrockenesHaar","JedenHaartyp"]
示例 fiddle。
我知道 OP 明确指定了 JSON路径,但为了完整起见,下面是如何使用 LINQ to JSON:
var values = jObject["typeOfHair"]["value"]
.SelectMany(v => v["values"])
.Where(v => (string)v["language"] == "de")
.Select(v => (string)v["value"])
.ToList();
我尝试了将近一个小时的不同方法,但我不明白;(
我的JSON对象是这样的:
"typeOfHair": {
"value": [
{
"code": "Dry Hair",
"values": [
{
"value": "DryHair",
"language": "en"
},
{
"value": "TrockenesHaar",
"language": "de"
}
]
},
{
"code": "Any Type of Hair",
"values": [
{
"value": "AnyTypeOfHair",
"language": "en"
},
{
"value": "JedenHaartyp",
"language": "de"
}
]
}
]
}
我的任务是使用 Newtonsoft.JSON 获取语言为 "de" 的所有值。 我目前的做法是:
JsonObject.SelectTokens("typeOfHair.value.values[?(@.language == 'de')].value").ToList()
有人可以帮我解决这个问题吗?
亲切的问候
你非常接近。您需要使用 JsonPATH 通配符 [*]
:
value
数组 typeOfHair.value[]
var values = JsonObject.SelectTokens("typeOfHair.value[*].values[?(@.language == 'de')].value")
// Convert from JValue to string
.Select(v => (string)v)
// Save in a list
.ToList();
并且,结果是:
["TrockenesHaar","JedenHaartyp"]
示例 fiddle。
我知道 OP 明确指定了 JSON路径,但为了完整起见,下面是如何使用 LINQ to JSON:
var values = jObject["typeOfHair"]["value"]
.SelectMany(v => v["values"])
.Where(v => (string)v["language"] == "de")
.Select(v => (string)v["value"])
.ToList();