0

0

使用 JOLT 进行 Shift 转换:从任意嵌套层级提取数据到单一列表

聖光之護

聖光之護

发布时间:2025-07-21 15:22:35

|

190人浏览过

|

来源于php中文网

原创

使用 jolt 进行 shift 转换:从任意嵌套层级提取数据到单一列表

本教程旨在解决在使用 JOLT 进行 JSON 转换时,如何从未知深度的嵌套结构中提取特定字段的值,并将这些值整合到一个数组中的问题。通过修改 JOLT shift 转换的 spec 文件,即使输入 JSON 的结构发生变化,也能保证输出始终是一个包含提取值的数组。

JOLT (JSON to JSON transform) 是一种强大的 JSON 转换工具,它允许用户通过简单的 JSON "spec" 文件来定义复杂的转换规则。在处理嵌套的 JSON 结构时,有时我们需要从不同层级提取数据,并将它们整合到一个数组中。本教程将介绍如何使用 JOLT 的 shift 操作来实现这一目标,并确保输出始终是一个数组,即使只有一个匹配项。

问题描述

假设我们有一个 JSON 数据,其中包含嵌套的 "item" 数组,数组的嵌套层级可能不确定。我们的目标是从这些嵌套的 "item" 中提取 "foo" 对象的 "nn" 字段的值,并将所有提取到的值放入一个名为 "type" 的数组中。

解决方案

关键在于 JOLT shift 操作的 spec 文件。我们需要使用通配符 "*" 来匹配任意层级的 "item" 数组,并使用 "[]" 后缀来强制生成数组。

以下是一个示例 spec 文件:

[
  {
    "operation": "shift",
    "spec": {
      "item": {
        "*": {
          "item": {
            "*": {
              "item": {
                "*": {
                  "foo": {
                    "nn": "type[]"
                  }
                }
              },
              "foo": {
                "nn": "type[]"
              }
            }
          },
          "foo": {
            "nn": "type[]"
          }
        }
      }
    }
  }
]

在这个 spec 文件中,我们使用了多个 "*" 通配符来匹配任意层级的 "item" 数组。关键在于 "nn": "type[]" 这一行。通过在 "type" 后面添加 "[]",我们告诉 JOLT 始终将提取到的 "nn" 值放入一个数组中,即使只有一个匹配项。

示例

AI发型设计
AI发型设计

虚拟发型试穿工具和发型模拟器

下载

假设我们的输入 JSON 如下:

{
  "id": 1,
  "item": [
    {
      "id": "1_1",
      "foo": {
        "id": 1232,
        "nn": "sdfsd"
      }
    }
  ]
}

使用上面的 spec 文件,JOLT 将生成以下输出:

{
  "type": [
    "sdfsd"
  ]
}

如果输入 JSON 包含多个 "item" 数组,例如:

{
  "id": 1,
  "item": [
    {
      "id": "1_1",
      "foo": {
        "id": 1232,
        "nn": "sdfsd"
      }
    },
    {
      "id": "1_2",
      "foo": {
        "id": 4567,
        "nn": "dfsds"
      }
    }
  ]
}

JOLT 将生成以下输出:

{
  "type": [
    "sdfsd",
    "dfsds"
  ]
}

注意事项

  • spec 文件中的通配符 "*" 匹配任何键名,因此请确保你的 JSON 结构符合预期,避免提取到不必要的数据。
  • 如果嵌套层级非常深,可以考虑使用更简洁的 JOLT spec 语法,例如使用 "@" 符号来引用父级节点。

总结

通过在 JOLT shift 操作的 spec 文件中使用 "[]" 后缀,我们可以强制 JOLT 生成数组输出,即使只有一个匹配项。这在处理嵌套的 JSON 结构时非常有用,可以确保输出数据的一致性。 这种方法使得我们能够从任意深度的嵌套结构中提取数据,并将它们整合到一个数组中,从而简化后续的数据处理流程。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

410

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

532

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

10

2026.01.12

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

106

2026.01.09

c++框架学习教程汇总
c++框架学习教程汇总

本专题整合了c++框架学习教程汇总,阅读专题下面的文章了解更多详细内容。

64

2026.01.09

学python好用的网站推荐
学python好用的网站推荐

本专题整合了python学习教程汇总,阅读专题下面的文章了解更多详细内容。

139

2026.01.09

学python网站汇总
学python网站汇总

本专题整合了学python网站汇总,阅读专题下面的文章了解更多详细内容。

13

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3.5万人学习

Pandas 教程
Pandas 教程

共15课时 | 0.9万人学习

ASP 教程
ASP 教程

共34课时 | 3.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号