mapper在查询json内容的数据
时间: 2023-12-14 18:37:53 浏览: 66
在查询 JSON 内容的数据时,可以使用 JSONPath 或者 jq 等工具来实现。其中,JSONPath 是一种类似于 XPath 的语法,可以用于在 JSON 数据中选择和操作节点;jq 是一个命令行 JSON 处理工具,可以从标准输入或文件中读取 JSON 数据,并进行过滤、映射、转换等操作。
使用 JSONPath 查询 JSON 数据时,可以使用 $ 作为根节点,使用 . 来访问对象属性或数组元素,例如:
```
{
"name": "Alice",
"age": 30,
"hobbies": ["reading", "swimming", "travelling"],
"address": {
"city": "Beijing",
"postcode": "100101"
}
}
```
- 查询 name 属性:`$.name`
- 查询 hobbies 数组的第二个元素:`$.hobbies[1]`
- 查询 address 对象的 postcode 属性:`$.address.postcode`
使用 jq 查询 JSON 数据时,可以通过管道符将多个 jq 命令组合起来,例如:
```
{
"users": [
{
"name": "Alice",
"age": 30,
"hobbies": ["reading", "swimming", "travelling"],
"address": {
"city": "Beijing",
"postcode": "100101"
}
},
{
"name": "Bob",
"age": 25,
"hobbies": ["music", "sports"],
"address": {
"city": "Shanghai",
"postcode": "200202"
}
}
]
}
```
- 查询所有用户的姓名:`cat data.json | jq '.users[].name'`
- 查询所有用户的年龄和地址城市:`cat data.json | jq '.users[] | {age: .age, city: .address.city}'`
- 查询年龄大于等于 30 的用户的姓名和爱好:`cat data.json | jq '.users[] | select(.age >= 30) | {name: .name, hobbies: .hobbies}'`
阅读全文