ApacheNifi如何将数组拆分并格式化为JSON?
创始人
2024-09-06 07:01:23
0
  1. 首先,使用'SplitJson”处理器将包含数组的 JSON 对象拆分为多个 JSON 对象。

  2. 接着,使用'EvaluateJsonPath”处理器和'JsonPath”表达式来提取数组的元素。

例如,假设有一个包含数组的 JSON 对象:

{ "id": 1, "name": "John", "hobbies": ["swimming", "running", "reading"] }

使用表达式'$.hobbies[*]”即可提取 hobbies 数组的所有元素:

swimming running reading

  1. 接下来,使用'AttributesToJson”处理器将提取到的元素格式化为 JSON 对象。

  2. 最后,使用'MergeContent”处理器将所有格式化后的 JSON 对象合并为一个 JSON 数据流。

以下是基于 Apache Nifi 实现此操作的示例代码:

将样例 JSON 投递到入口处+->SplitJson+->EvaluateJsonPath,分为多个流:

$.id -> # id

$.name -> # name

$.hobbies[*] -> # hobby

每个单独的流+->AttributesToJson+->MergeContent,最终拼成完整的 JSON。

假设我们有以下 JSON 数据流: { "id": 1, "name": "John", "hobbies": ["swimming", "running", "reading"] }

通过以上处理器,我们可以获得以下结果:

流1: { "id": 1 }

流2: { "name": "John" }

流3: { "hobby": "swimming" }

流4: { "hobby": "running" }

流5: { "hobby": "reading" }

最终,我们使用'MergeContent”处理器将所有流合并为完整的 JSON 数据流:

输出: { "id": 1, "name": "John", "hobbies": [ { "hobby": "swimming" }, { "

相关内容

热门资讯

银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...