0

0

Jolt Transform:将数组展开为多个对象并提取首元素字段生成新结构

花韻仙語

花韻仙語

发布时间:2026-02-10 11:39:19

|

775人浏览过

|

来源于php中文网

原创

Jolt Transform:将数组展开为多个对象并提取首元素字段生成新结构

本文详解如何使用 jolt 的 `shift` 操作正确复制原始数组、同时从数组首项中提取 `start` 和 `end` 字段构建独立的 `date` 数组,避免常见索引覆盖与路径匹配错误。

在使用 Jolt 进行 JSON 转换时,一个典型难点是:既要完整保留原始数组结构(如 "steps"),又要基于数组某一项(如首项)派生出全新字段结构(如 "date" 数组)。初学者常误用通配符 * 与具体索引 0 混合在同一层级,导致数组被意外覆盖或仅处理最后一项——这正是原问题中 "*": "steps[]" 未生效的根本原因。

? 问题根源分析

原 spec 中:

"steps": {
  "*": "steps[]",   // ✅ 正确:将 steps[*] 逐个追加到输出 steps 数组
  "0": {            // ❌ 冲突:同一层级下,"0" 是 "*” 的子集,但 Jolt 不支持“先通配再单独索引”的并行匹配
    "#startDate": "date[0].name",
    "start": "date[0].value",
    "end": "date[1].value",
    "#endDate": "date[1].name"
  }
}

Jolt 的 shift 操作对同一输入键(steps)的多个子路径规则不保证执行顺序,且当 * 已遍历全部元素后,"0" 规则可能被忽略或覆盖,最终仅 steps[0] 生效,造成数据丢失。

✅ 正确解法:利用动态引用 &1 与层级隔离

核心思路:将输入顶层键(steps)视为通用占位符,用 &1 动态捕获其原始键名,确保完整透传;再单独处理其第 0 项以构造 date

推荐 spec 如下:

Socratic Lab
Socratic Lab

AI驱动的在线知识社区和AI知识搜索平台

下载
[
  {
    "operation": "shift",
    "spec": {
      "*": {
        "@": "&1",
        "0": {
          "#startDate": "date[0].name",
          "start": "date[0].value",
          "#endDate": "date[1].name",
          "end": "date[1].value"
        }
      }
    }
  }
]

✨ 关键语法解析:

  • "*":匹配输入根对象的所有键(此处即 "steps");
  • "@": "&1":@ 表示原值(整个 steps 数组),&1 表示 上 1 层路径中的第一个捕获组(即 * 匹配到的键名 "steps"),等价于 "steps": "steps",实现无损复制;
  • "0":在 steps 数组内部精准定位首元素(索引 0),从中提取字段并映射至 date 数组。
? 提示:&n 是 Jolt 的路径变量引用语法,&0 = 当前层级键名,&1 = 上一层键名,依此类推。此处 &1 确保了任意输入键名(如 "tasks" 替代 "steps")均可自动适配。

? 验证示例

输入 JSON:

{
  "steps": [
    {
      "end": "2023-01-27T09:19:29.849298Z",
      "id": "1",
      "start": "2023-01-27T09:18:24.59325Z",
      "name": "foo"
    },
    {
      "end": "2023-01-28T09:19:29.849298Z",
      "id": "2",
      "start": "2023-01-28T09:18:24.59325Z",
      "name": "bar"
    }
  ]
}

经上述 spec 处理后,精确输出:

{
  "steps": [
    {
      "end": "2023-01-27T09:19:29.849298Z",
      "id": "1",
      "start": "2023-01-27T09:18:24.59325Z",
      "name": "foo"
    },
    {
      "end": "2023-01-28T09:19:29.849298Z",
      "id": "2",
      "start": "2023-01-28T09:18:24.59325Z",
      "name": "bar"
    }
  ],
  "date": [
    {
      "name": "startDate",
      "value": "2023-01-27T09:18:24.59325Z"
    },
    {
      "name": "endDate",
      "value": "2023-01-27T09:19:29.849298Z"
    }
  ]
}

⚠️ 注意事项与最佳实践

  • *永远避免在同一 shift 规则中对同一输入路径混用 `和数字索引**(如"steps": { "*": ..., "0": ... }`),应提升层级统一匹配;
  • 若需从任意指定索引(非仅 0)提取字段,可将 "0" 替换为 "1"、"2" 等,但需确保数组长度足够;
  • date 数组长度固定为 2,若需动态扩展(如按步骤数生成多个日期对),需改用 modify-overwrite-beta + 循环逻辑,shift 本身不支持迭代;
  • 建议在 Jolt Demo Site 中实时调试 spec,观察中间路径匹配过程。

掌握 &n 引用与层级化 shift 结构,是写出健壮、可维护 Jolt 转换逻辑的关键一步。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

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

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

435

2023.08.07

json是什么
json是什么

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

543

2023.08.23

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

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

317

2023.10.13

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

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

79

2025.09.10

包子漫画网页版入口与全集阅读指南_正版免费漫画快速访问方法
包子漫画网页版入口与全集阅读指南_正版免费漫画快速访问方法

本专题汇总了包子漫画官网和网页版入口,提供最新章节抢先看方法、正版免费阅读指南,以及稳定访问方式,帮助用户快速直达包子漫画页面,无广告畅享全集漫画内容。

43

2026.02.10

MC.JS网页版快速畅玩指南_MC.JS官网在线入口及免安装体验方法
MC.JS网页版快速畅玩指南_MC.JS官网在线入口及免安装体验方法

本专题汇总了MC.JS官网入口和网页版快速畅玩方法,提供免安装访问、不同版本(1.8.8、1.12.8)在线体验指南,以及正版网页端操作说明,帮助玩家轻松进入MC.JS世界,实现即时畅玩与高效体验。

26

2026.02.10

谷歌邮箱网页版登录与注册全指南_Gmail账号快速访问与安全操作教程
谷歌邮箱网页版登录与注册全指南_Gmail账号快速访问与安全操作教程

本专题汇总了谷歌邮箱网页版的最新登录入口和注册方法,详细提供官方账号快速访问方式、网页版操作教程及安全登录技巧,帮助用户轻松管理Gmail邮箱账户,实现高效、安全的邮箱使用体验。

21

2026.02.10

铁路12306订票与退改全攻略_高效购票与座位选取技巧
铁路12306订票与退改全攻略_高效购票与座位选取技巧

本专题全面汇总铁路12306订票、退票、改签及候补订单操作技巧,提供车厢座位分布参考、抢票攻略和高铁安检注意事项,帮助新手用户快速掌握高效购票与退改流程,提高出行效率和体验。

17

2026.02.10

TensorFlow2深度学习模型实战与优化
TensorFlow2深度学习模型实战与优化

本专题面向 AI 与数据科学开发者,系统讲解 TensorFlow 2 框架下深度学习模型的构建、训练、调优与部署。内容包括神经网络基础、卷积神经网络、循环神经网络、优化算法及模型性能提升技巧。通过实战项目演示,帮助开发者掌握从模型设计到上线的完整流程。

0

2026.02.10

热门下载

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

精品课程

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

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