【御控工业物联网】 Java JSON结构转换、JSON结构重构、JSON结构互换(17):数组To对象——键值互换属性重组

news2025/1/10 17:06:43

文章目录

  • 一、JSON结构转换是什么?
  • 二、核心构件之转换映射
  • 三、案例之《JSON数组 To JSON对象》
  • 四、代码实现
  • 五、在线转换工具
  • 六、技术资料


一、JSON结构转换是什么?

JSON结构转换指的是将一个JSON对象或JSON数组按照一定规则进行重组、筛选、映射或转换,生成新的JSON对象或数组的过程。这种转换可以包括改变JSON数据的结构、提取特定字段、合并多个JSON数据,或者对数据进行计算和处理等操作。

在JSON结构转换中,常见的操作包括:

  • 提取字段:从一个JSON对象中提取特定字段,生成新的JSON对象。
  • 过滤数据:根据条件过滤JSON数据,生成符合条件的新JSON对象或数组。
  • 映射转换:将一个JSON对象中的字段映射到另一个字段,生成新的JSON对象。
  • 合并数据:将多个JSON对象或数组合并成一个新的JSON对象或数组。

JSON结构转换通常在数据处理、数据清洗、数据分析等场景中广泛应用。通过结构转换,可以根据需求定制化地处理JSON数据,使其符合特定的业务逻辑或数据格式要求。
为此我们提供了三个简单开源的类库(JavaScript类库、Java类库、.Net类库),接下来我们对JS类库进行详细讲解。

二、核心构件之转换映射

在对类库进行详细讲解之前,我们先来介绍一下转换映射。
转换映射是JSON结构转换的核心构件,工具依据分析转换映射来进行源与目标JSON结构的转化。

转换映射的构成如下:

{
    "AimJsonPath": "root.org",
	"OrgJsonPath": "root.aim",
	"TranType": 4,
    "Options":{
        "KeyInitIndex":0,
        "AddElementsOption":"1",        
		"TranOP":"1",  
        "TranWay":"1" 
    }
}

转换映射的属性介绍如下:

  1. AimJsonPath
    目标结构路径
  2. OrgJsonPath
    目标结构路径
  3. TranType
    转换类型 1:源Key->目标Key 2:源Key->目标Value 3:源Value->目标Key 4:源Value->目标Value
  4. Options.KeyInitIndex
    自动生成的元素的起始索引(默认为0)
  5. Options.AddElementsOption
    1:追加新元素到数组/对象 (默认为1)
    2:替换数组/对象的原有属性
  6. Options.TranOP
    1:将源子元素复制到目标,使用源子元素的Key(默认为1)
    2:将源子元素复制到目标,为源子元素新生成Key
    3:依据源元素在目标构建同等数量的目标子元素
  7. Options.TranWay
    1:交叉映射 ( 默认为1)
    2:一对一映射

三、案例之《JSON数组 To JSON对象》

源JSON结构:

{
  "devOrg":[{
    "idOrg": "0001",
    "proOrg": [{
      "idOrg": "",
      "nOrg": "11",
      "dtOrg": "",
      "vOrg": "1.1",
      "qOrg": ""
    }]
  }]
}

目标JSON结构:

{
  "devAim": {
    "642fccd1Aim": {
      "1Aim": "111",
      "2Aim": "122"
    },
    "timeAim": 1682476529
  }
}

转换需求:

以下需求分别执行

1.将源结构的“devOrg”键替换到目标结构的“devAim”值
2.将源结构的“devOrg”键追加到目标结构的“devAim”值
3.将源结构的“devOrg”值替换到目标结构的“devAim”值
4.将源结构的“devOrg”值追加到目标结构的“devAim”值
5.将源结构的“devOrg[0]”键追加到目标结构的“devAim.642fccd1Aim”值
6.将源结构的“devOrg[0]”值追加到目标结构的“devAim.642fccd1Aim”值
7.将源结构的“devOrg[0]”键追加到目标结构的“devAim.642fccd1Aim.1Aim”值
8.将源结构的“devOrg[0]”值追加到目标结构的“devAim.642fccd1Aim.1Aim”值

四、代码实现

1.将源结构的“devOrg”键替换到目标结构的“devAim”值


import com.fasterxml.jackson.databind.ObjectMapper;

import java.util.ArrayList;
import java.util.List;
/**
 * 对象转换对象
 */
public class Main {
    public static void main(String[] args) {
        ObjectMapper mapper = new ObjectMapper();
        String orgJson = "{\"devOrg\":[{\"idOrg\":\"0001\",\"proOrg\":[{\"idOrg\":\"\",\"nOrg\":\"11\",\"dtOrg\":\"\",\"vOrg\":\"1.1\",\"qOrg\":\"\"}]}]}"; // JSON字符串
        String aimJson = "{\"devAim\":{\"642fccd1Aim\":{\"1Aim\":\"111\",\"2Aim\":\"122\"},\"timeAim\":1682476529}}"; // JSON字符串
        List<JsonMapping> jsonMappings = new ArrayList<>();
        jsonMappings.add(new JsonMapping("root.devAim", "root.devOrg", 2,new JsonMappingOptions(0,2,1,1)));
        JsonTranferUtil jsonTranferUtil = null;
        String result ="";
        try {
            jsonTranferUtil = new JsonTranferUtil(orgJson, aimJson, jsonMappings);
            result = jsonTranferUtil.tranJson();
        } catch (Exception e) {
            e.printStackTrace();
        }
        System.out.println("******************结果 **********************");
        System.out.println(result);
    }
}

执行结果如下:

在这里插入图片描述

2.将源结构的“devOrg”键追加到目标结构的“devAim”值

import com.fasterxml.jackson.databind.ObjectMapper;

import java.util.ArrayList;
import java.util.List;
/**
 * 对象转换对象
 */
public class Main {
    public static void main(String[] args) {
        ObjectMapper mapper = new ObjectMapper();
        String orgJson = "{\"devOrg\":[{\"idOrg\":\"0001\",\"proOrg\":[{\"idOrg\":\"\",\"nOrg\":\"11\",\"dtOrg\":\"\",\"vOrg\":\"1.1\",\"qOrg\":\"\"}]}]}"; // JSON字符串
        String aimJson = "{\"devAim\":{\"642fccd1Aim\":{\"1Aim\":\"111\",\"2Aim\":\"122\"},\"timeAim\":1682476529}}"; // JSON字符串
        List<JsonMapping> jsonMappings = new ArrayList<>();
        jsonMappings.add(new JsonMapping("root.devAim", "root.devOrg", 2,new JsonMappingOptions(0,1,1,1)));
        JsonTranferUtil jsonTranferUtil = null;
        String result ="";
        try {
            jsonTranferUtil = new JsonTranferUtil(orgJson, aimJson, jsonMappings);
            result = jsonTranferUtil.tranJson();
        } catch (Exception e) {
            e.printStackTrace();
        }
        System.out.println("******************结果 **********************");
        System.out.println(result);
    }
}


执行结果如下:
在这里插入图片描述

3.将源结构的“devOrg”值替换到目标结构的“devAim”值


import com.fasterxml.jackson.databind.ObjectMapper;

import java.util.ArrayList;
import java.util.List;
/**
 * 对象转换对象
 */
public class Main {
    public static void main(String[] args) {
        ObjectMapper mapper = new ObjectMapper();
        String orgJson = "{\"devOrg\":[{\"idOrg\":\"0001\",\"proOrg\":[{\"idOrg\":\"\",\"nOrg\":\"11\",\"dtOrg\":\"\",\"vOrg\":\"1.1\",\"qOrg\":\"\"}]}]}"; // JSON字符串
        String aimJson = "{\"devAim\":{\"642fccd1Aim\":{\"1Aim\":\"111\",\"2Aim\":\"122\"},\"timeAim\":1682476529}}"; // JSON字符串
        List<JsonMapping> jsonMappings = new ArrayList<>();
        jsonMappings.add(new JsonMapping("root.devAim", "root.devOrg", 4,new JsonMappingOptions(0,2,1,1)));
        JsonTranferUtil jsonTranferUtil = null;
        String result ="";
        try {
            jsonTranferUtil = new JsonTranferUtil(orgJson, aimJson, jsonMappings);
            result = jsonTranferUtil.tranJson();
        } catch (Exception e) {
            e.printStackTrace();
        }
        System.out.println("******************结果 **********************");
        System.out.println(result);
    }
}


执行结果如下:

在这里插入图片描述

4.将源结构的“devOrg”值追加到目标结构的“devAim”值

import com.fasterxml.jackson.databind.ObjectMapper;

import java.util.ArrayList;
import java.util.List;
/**
 * 对象转换对象
 */
public class Main {
    public static void main(String[] args) {
        ObjectMapper mapper = new ObjectMapper();
        String orgJson = "{\"devOrg\":[{\"idOrg\":\"0001\",\"proOrg\":[{\"idOrg\":\"\",\"nOrg\":\"11\",\"dtOrg\":\"\",\"vOrg\":\"1.1\",\"qOrg\":\"\"}]}]}"; // JSON字符串
        String aimJson = "{\"devAim\":{\"642fccd1Aim\":{\"1Aim\":\"111\",\"2Aim\":\"122\"},\"timeAim\":1682476529}}"; // JSON字符串
        List<JsonMapping> jsonMappings = new ArrayList<>();
        jsonMappings.add(new JsonMapping("root.devAim", "root.devOrg", 4,new JsonMappingOptions(0,1,1,1)));
        JsonTranferUtil jsonTranferUtil = null;
        String result ="";
        try {
            jsonTranferUtil = new JsonTranferUtil(orgJson, aimJson, jsonMappings);
            result = jsonTranferUtil.tranJson();
        } catch (Exception e) {
            e.printStackTrace();
        }
        System.out.println("******************结果 **********************");
        System.out.println(result);
    }
}

执行结果如下:

在这里插入图片描述

5.将源结构的“devOrg[0]”键追加到目标结构的“devAim.642fccd1Aim”值


import com.fasterxml.jackson.databind.ObjectMapper;

import java.util.ArrayList;
import java.util.List;
/**
 * 对象转换对象
 */
public class Main {
    public static void main(String[] args) {
        ObjectMapper mapper = new ObjectMapper();
        String orgJson = "{\"devOrg\":[{\"idOrg\":\"0001\",\"proOrg\":[{\"idOrg\":\"\",\"nOrg\":\"11\",\"dtOrg\":\"\",\"vOrg\":\"1.1\",\"qOrg\":\"\"}]}]}"; // JSON字符串
        String aimJson = "{\"devAim\":{\"642fccd1Aim\":{\"1Aim\":\"111\",\"2Aim\":\"122\"},\"timeAim\":1682476529}}"; // JSON字符串
        List<JsonMapping> jsonMappings = new ArrayList<>();
        jsonMappings.add(new JsonMapping("root.devAim.642fccd1Aim", "root.devOrg[0]", 2,new JsonMappingOptions(0,1,1,1)));
        JsonTranferUtil jsonTranferUtil = null;
        String result ="";
        try {
            jsonTranferUtil = new JsonTranferUtil(orgJson, aimJson, jsonMappings);
            result = jsonTranferUtil.tranJson();
        } catch (Exception e) {
            e.printStackTrace();
        }
        System.out.println("******************结果 **********************");
        System.out.println(result);
    }
}


执行结果如下:

在这里插入图片描述

6.将源结构的“devAim[0]”值追加到目标结构的“devAim.642fccd1Aim”值

import com.fasterxml.jackson.databind.ObjectMapper;

import java.util.ArrayList;
import java.util.List;
/**
 * 对象转换对象
 */
public class Main {
    public static void main(String[] args) {
        ObjectMapper mapper = new ObjectMapper();
        String orgJson = "{\"devOrg\":[{\"idOrg\":\"0001\",\"proOrg\":[{\"idOrg\":\"\",\"nOrg\":\"11\",\"dtOrg\":\"\",\"vOrg\":\"1.1\",\"qOrg\":\"\"}]}]}"; // JSON字符串
        String aimJson = "{\"devAim\":{\"642fccd1Aim\":{\"1Aim\":\"111\",\"2Aim\":\"122\"},\"timeAim\":1682476529}}"; // JSON字符串
        List<JsonMapping> jsonMappings = new ArrayList<>();
        jsonMappings.add(new JsonMapping("root.devAim.642fccd1Aim", "root.devOrg[0]", 4,new JsonMappingOptions(0,1,1,1)));
        JsonTranferUtil jsonTranferUtil = null;
        String result ="";
        try {
            jsonTranferUtil = new JsonTranferUtil(orgJson, aimJson, jsonMappings);
            result = jsonTranferUtil.tranJson();
        } catch (Exception e) {
            e.printStackTrace();
        }
        System.out.println("******************结果 **********************");
        System.out.println(result);
    }
}


执行结果如下:
在这里插入图片描述

7.将源结构的“devOrg[0]”键追加到目标结构的“devAim.642fccd1Aim.1Aim”值


import com.fasterxml.jackson.databind.ObjectMapper;

import java.util.ArrayList;
import java.util.List;
/**
 * 对象转换对象
 */
public class Main {
    public static void main(String[] args) {
        ObjectMapper mapper = new ObjectMapper();
        String orgJson = "{\"devOrg\":[{\"idOrg\":\"0001\",\"proOrg\":[{\"idOrg\":\"\",\"nOrg\":\"11\",\"dtOrg\":\"\",\"vOrg\":\"1.1\",\"qOrg\":\"\"}]}]}"; // JSON字符串
        String aimJson = "{\"devAim\":{\"642fccd1Aim\":{\"1Aim\":\"111\",\"2Aim\":\"122\"},\"timeAim\":1682476529}}"; // JSON字符串
        List<JsonMapping> jsonMappings = new ArrayList<>();
        jsonMappings.add(new JsonMapping("root.devAim.642fccd1Aim.1Aim", "root.devOrg[0]", 2,new JsonMappingOptions(0,1,1,1)));
        JsonTranferUtil jsonTranferUtil = null;
        String result ="";
        try {
            jsonTranferUtil = new JsonTranferUtil(orgJson, aimJson, jsonMappings);
            result = jsonTranferUtil.tranJson();
        } catch (Exception e) {
            e.printStackTrace();
        }
        System.out.println("******************结果 **********************");
        System.out.println(result);
    }
}



执行结果如下:
在这里插入图片描述

8.将源结构的“devAim[0]”值追加到目标结构的“devAim.642fccd1Aim.1Aim”值


import com.fasterxml.jackson.databind.ObjectMapper;

import java.util.ArrayList;
import java.util.List;
/**
 * 对象转换对象
 */
public class Main {
    public static void main(String[] args) {
        ObjectMapper mapper = new ObjectMapper();
        String orgJson = "{\"devOrg\":[{\"idOrg\":\"0001\",\"proOrg\":[{\"idOrg\":\"\",\"nOrg\":\"11\",\"dtOrg\":\"\",\"vOrg\":\"1.1\",\"qOrg\":\"\"}]}]}"; // JSON字符串
        String aimJson = "{\"devAim\":{\"642fccd1Aim\":{\"1Aim\":\"111\",\"2Aim\":\"122\"},\"timeAim\":1682476529}}"; // JSON字符串
        List<JsonMapping> jsonMappings = new ArrayList<>();
        jsonMappings.add(new JsonMapping("root.devAim.642fccd1Aim.1Aim", "root.devOrg[0]", 4,new JsonMappingOptions(0,1,1,1)));
        JsonTranferUtil jsonTranferUtil = null;
        String result ="";
        try {
            jsonTranferUtil = new JsonTranferUtil(orgJson, aimJson, jsonMappings);
            result = jsonTranferUtil.tranJson();
        } catch (Exception e) {
            e.printStackTrace();
        }
        System.out.println("******************结果 **********************");
        System.out.println(result);
    }
}

执行结果如下:

在这里插入图片描述

五、在线转换工具

为了让使用者更加方便的配置出映射关系,为此开发了一套在线转换工具,可在工具中通过拖拽即可配置想要的结构转换关系,并可对转换关系所能实现的效果实时进行预览更改。

工具地址:数据转换工具
在这里插入图片描述

六、技术资料

  • Github:edq-ebara/data-transformation-javascript: 数据转化(javascript) (github.com)
  • 技术探讨QQ群:775932762
  • 工具连接:数据转换工具
  • 御控官网:https://www.yu-con.com/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1707585.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2024第三届AIGC开发者大会圆桌论坛:AI Agent中国落地发展现状及多模态结合具身智能的发展展望

在2024年第三届AIGC开发者大会上&#xff0c;多位业内专家齐聚一堂&#xff0c;共同探讨了AI Agent在中国的落地发展现状以及多模态结合具身智能的发展前景。本次圆桌论坛的嘉宾包括&#xff1a; Fast JP作者于金龙Agent创始人莫西莫必胜作者秦瑞January Agent创始人李晨 多模…

JavaEE:Servlet创建和使用及生命周期介绍

目录 ▐ Servlet概述 ▐ Servlet的创建和使用 ▐ Servlet中方法介绍 ▐ Servlet的生命周期 ▐ Servlet概述 • Servlet是Server Applet的简称&#xff0c;意思是 用Java编写的服务器端的程序&#xff0c;Servlet被部署在服务器中&#xff0c;而服务器负责管理并调用Servle…

【第5章】SpringBoot整合Druid

文章目录 前言一、启动器二、配置1.JDBC 配置2.连接池配置3. 监控配置 三、配置多数据源1. 添加配置2. 创建数据源 四、配置 Filter1. 配置Filter2. 可配置的Filter 五、获取 Druid 的监控数据六、案例1. 问题2. 引入库3. 配置4. 配置类5. 测试类6. 测试结果 七、案例 ( 推荐 )…

vivo X100 Ultra自称销售额破5亿,真实销量成谜?

文/张诗雨 5月28日9点&#xff0c;vivo 正式启动了其旗舰新机vivo X100 Ultra的全渠道销售工作。这款新机&#xff0c;早在5月13日就已正式亮相&#xff0c;并推出了三种存储容量的版本&#xff0c;分别是12GB256GB、16GB512GB以及16GB1TB&#xff0c;而相应的售价也不低&…

短道速滑短视频:四川京之华锦信息技术公司

短道速滑短视频&#xff1a;冰雪激情的视觉盛宴 随着冬奥会的热度不断攀升&#xff0c;短道速滑作为其中一项紧张刺激、充满观赏性的运动&#xff0c;受到了越来越多人的关注。而在社交媒体和短视频平台的助力下&#xff0c;短道速滑短视频成为了人们了解、欣赏这项运动的新窗…

vxe-form-design 表单设计器的使用

vxe-form-design 在 vue3 中表单设计器的使用 查看官网 https://vxeui.com 安装 npm install vxe-pc-ui // ... import VxeUI from vxe-pc-ui import vxe-pc-ui/lib/style.css // ...// ... createApp(App).use(VxeUI).mount(#app) // ...使用 github vxe-form-design 用…

Linux软硬链接详解

软链接&#xff1a; ln -s file1 file2//file1为目标文件&#xff0c;file2为软链接文件 演示&#xff1a; 从上图可以得出&#xff1a; 软链接本质不是同一个文件&#xff0c;因为inode不同。 作用&#xff1a; 软连接就像是Windows里的快捷方式&#xff0c;里面存放的是目标…

Llama模型家族训练奖励模型Reward Model技术及代码实战(二)从用户反馈构建比较数据集

LlaMA 3 系列博客 基于 LlaMA 3 LangGraph 在windows本地部署大模型 &#xff08;一&#xff09; 基于 LlaMA 3 LangGraph 在windows本地部署大模型 &#xff08;二&#xff09; 基于 LlaMA 3 LangGraph 在windows本地部署大模型 &#xff08;三&#xff09; 基于 LlaMA…

DES加密算法笔记

【DES加密算法&#xff5c;密码学&#xff5c;信息安全】https://www.bilibili.com/video/BV1KQ4y127AT?vd_source7ad69e0c2be65c96d9584e19b0202113 根据此视频学习 DES是对称密码中的分组加密算法 (分组加密对应流加密算法) 流加密算法就是一个字节一个字节加密 分组加…

Mybatis枚举类型转换

Mybatis枚举类型转换 类型转换器源码分析 在Mybatis的TypeHandlerRegistry中&#xff0c;添加了常用的类转换器&#xff0c;其中默认的枚举类型转换器是EnumTypeHandler。 public final class TypeHandlerRegistry {....public TypeHandlerRegistry(Configuration configura…

第 8 章 机器人平台设计之传感器(自学二刷笔记)

重要参考&#xff1a; 课程链接:https://www.bilibili.com/video/BV1Ci4y1L7ZZ 讲义链接:Introduction Autolabor-ROS机器人入门课程《ROS理论与实践》零基础教程 8.6.1 传感器_激光雷达简介 激光雷达是现今机器人尤其是无人车领域及最重要、最关键也是最常见的传感器之一&…

opencv c++编程基础

1、图片的本质 图像在 OpenCV 中的本质 在 OpenCV 中&#xff0c;图像被表示为一个多维数组&#xff0c;其中每个元素对应于图像中的单个像素。图像的维度取决于其通道数和像素数。 **通道数&#xff1a;**图像可以有多个通道&#xff0c;每个通道存储图像的不同信息。例如&…

RabbitMQ 发布订阅

RabbitMQ 发布订阅视频学习地址&#xff1a; 简单模式下RabbitMQ 发布者发布消息 消费者消费消息 Publist/Subscribe 发布订阅 在 RabbitMQ 中&#xff0c;发布订阅模式是一种消息传递方式&#xff0c;其中发送者&#xff08;发布者&#xff09;不会将消息直接发送到特 定的…

8.微信小程序之自定义组件

目录 1. 创建-注册-使用组件 1.1 创建自定义组件 1.2 使用自定义组件 2. 自定义组件-数据和方法 3. 自定义组件-属性 4. 组件 wxml 的 slot 5. 组件样式以及注意事项 6. 组件样式隔离 7. 数据监听器 8. 组件间通信与事件 8.1 父往子传值 8.2 子往父传值 8.3 获取…

十四天学会Vue——Vue核心(理论+实战)上篇(第一天)

一、Vue核心&#xff08;上篇&#xff09; 热身tops&#xff1a;选取开发模式 ①用于开发模式 我们只需要知道 我们是开发模式&#xff0c;开发模式他会跟你提示代码出现错误的地方以及出错原因&#xff0c;而生产模式比较简洁。 ②用于生产模式 1.1 new Vue()实例 了解Vue&a…

shell脚本的基础应用

规范脚本的构成 #&#xff01;/bin/bash # 注释信息 可执行的语句 执行脚本的方法 有1.添加x权限 ,绝对路经&#xff0c;或者相对路径2. 使用解释器 不需加x,root...bash...bash..echo 3,用source&#xff0c; 开机root ...bash ...echo bash -x /opt/test01.sh &#xff…

Linux网络-Socket套接字_Windows与Linux端双平台基于Udp传输协议进行多线程跨平台的服务器与客户端网络通信的简易聊天室实现

文章目录 一、Socket套接字二、socket 常见API1. int socket(int domain, int type, int protocol);2. int bind(int socket, const struct sockaddr *address, socklen_t address_len);struct sockaddr 3. ssize_t recvfrom(int socket, void *restrict buffer, size_t length…

话术巧妙分隔沟通效果更佳看看这个小技巧

客服回复客户咨询&#xff0c;如果遇到比较复杂的问题&#xff0c;经常会有大段的文字回复&#xff0c;用聊天宝的分段符功能&#xff0c;在需要分段的地方点击右上角的“插入分隔符”&#xff0c;就可以在指定位置分段&#xff0c;实现多段发送的目的。 前言 客服回复客户咨询…

Python-3.12.0文档解读-内置函数map()详细说明+记忆策略+常用场景+巧妙用法+综合技巧

一个认为一切根源都是“自己不够强”的INTJ 个人主页&#xff1a;用哲学编程-CSDN博客专栏&#xff1a;每日一题——举一反三Python编程学习Python内置函数 Python-3.12.0文档解读 目录 详细说明 map(function, iterable, *iterables) 参数 返回值 示例 注意事项 参考…

CHI Read传输——CHI(3)

目录 一、Read操作概览 二、DMT(Direct Memory Transfer) 三、DCT (Direct Cache Transfer) 四、without Direct Data Transfer 五、ReadNoSnp and ReadOnce* structure with DMT 本篇我们来介绍一下CHI传输类型中的Read 一、Read操作概览 read操作有以下几种&#xff1…