首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >根元素的JSONPath

根元素的JSONPath
EN

Stack Overflow用户
提问于 2022-05-24 12:15:47
回答 1查看 174关注 0票数 0

我在AWS函数(操场:参数选项卡)中使用了操场:参数选项卡

在本例中,如果我们有一个JSON输入:

代码语言:javascript
复制
{
  "movies": [
    {
      "genre": "crime",
      "director": "Quentin Tarantino",
      "title": "Reservoir Dogs",
      "year": 1992
    },
    {
      "genre": "action",
      "director": "Brian De Palma",
      "title": "Mission: Impossible",
      "year": 1996,
      "staring": [
        "Tom Cruise"
      ]
    }
  ],
  "metadata": {
    "lastUpdated": "2020-05-27T08:00:00.000Z"
  },
  "stringJson": "{\"arr\": [1, 2, 3, 4, 5], \"bool\": true, \"null\": null, \"number\": 1}"
}

这样的参数:

代码语言:javascript
复制
{
    "test.$": "$.metadata"
}

我们将得到这样的输出:

代码语言:javascript
复制
{
  "test": {
    "lastUpdated": "2020-05-27T08:00:00.000Z"
  }
}

而我想要

代码语言:javascript
复制
{
  "lastUpdated": "2020-05-27T08:00:00.000Z"
}

或者说更好的是,除了一个人:

代码语言:javascript
复制
{
  "movies": [
    {
      "genre": "crime",
      "director": "Quentin Tarantino",
      "title": "Reservoir Dogs",
      "year": 1992
    },
    {
      "genre": "action",
      "director": "Brian De Palma",
      "title": "Mission: Impossible",
      "year": 1996,
      "staring": [
        "Tom Cruise"
      ]
    }
  ],
  "metadata": {
    "lastUpdated": "2020-05-27T08:00:00.000Z"
  }
}

如何将元素(或所有元素)放在根中?

我尝试过这样的参数:

代码语言:javascript
复制
{
    "$": "$.metadata.lastUpdated"
}

代码语言:javascript
复制
{
    "$": "$.(?[@ != 'stringJson'])"
}

但这些都不适合我。

EN

回答 1

Stack Overflow用户

发布于 2022-05-24 13:36:45

InputPath设置为$.metadata以获取:

代码语言:javascript
复制
{
  "lastUpdated": "2020-05-27T08:00:00.000Z"
}

引用路径( InputPath接受的路径类型)是有限的,因为它只能识别整个JSON结构中的单个节点。

您不能本机排除除'x‘元素之外的所有元素。

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

https://stackoverflow.com/questions/72362724

复制
相关文章

相似问题

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