如何将两个对象合并在一起,对象合并工具类的实现

一、工具类概述

在编程中,经常需要对数据进行合并操作。所以我写了一个ModelMergeUtil 工具类用于将不同的对象或数据进行合并,以满足在特定场景下的数据整合需求。以下是工具类的使用说明

二、方法详解

(一)merge(String originJsonStr, String currentJsonStr, Class<T> clazz) 方法

这个方法接受两个 JSON 字符串和一个类类型作为参数。它首先将这两个 JSON 字符串转换为 Map 对象,然后进行数据合并,最后将合并后的 Map 转换为指定类型的对象并返回。

以下是针对这个方法的测试示例:

import static org.junit.jupiter.api.Assertions.*;
import org.junit.jupiter.api.Test;

class ModelMergeUtilTest {

    @Test
    void testMergeWithJsonStringsAndClass() {
        String originJsonStr = "{\"name\":\"Alice\",\"age\":20}";
        String currentJsonStr = "{\"age\":25,\"city\":\"London\"}";
        ModelMergeUtil modelMergeUtil = new ModelMergeUtil();

        Person mergedPerson = modelMergeUtil.merge(originJsonStr, currentJsonStr, Person.class);

        assertEquals("Alice", mergedPerson.getName());
        assertEquals(25, mergedPerson.getAge());
        assertEquals("London", mergedPerson.getCity());
    }
}

class Person {
    private String name;
    private int age;
    private String city;

    // 省略 getter 和 setter 方法
}

(二)merge(T originObject, T currentObject, Class<T> clazz) 方法

该方法接受两个对象和一个类类型作为参数。它会将这两个对象转换为 JSON 字符串,然后执行与上述方法类似的合并操作。

对应的测试方法如下:

@Test
void testMergeWithObjectsAndClass() {
    Person originPerson = new Person();
    originPerson.setName("Bob");
    originPerson.setAge(30);

    Person currentPerson = new Person();
    currentPerson.setAge(35);
    currentPerson.setCity("New York");

    ModelMergeUtil modelMergeUtil = new ModelMergeUtil();

    Person mergedPerson = modelMergeUtil.merge(originPerson, currentPerson, Person.class);

    assertEquals("Bob", mergedPerson.getName());
    assertEquals(35, mergedPerson.getAge());
    assertEquals("New York", mergedPerson.getCity());
}

(三)merge(String originJsonStr, String currentJsonStr) 方法

此方法接受两个 JSON 字符串,将其转换为 Map 对象进行合并,最后再转换回 JSON 字符串返回。

测试代码如下:

@Test
void testMergeWithJsonStrings() {
    String originJsonStr = "{\"name\":\"Eve\",\"age\":22}";
    String currentJsonStr = "{\"age\":28,\"occupation\":\"Engineer\"}";
    ModelMergeUtil modelMergeUtil = new ModelMergeUtil();

    String mergedJson = modelMergeUtil.merge(originJsonStr, currentJsonStr);

    assertTrue(mergedJson.contains("name\":\"Eve\""));
    assertTrue(mergedJson.contains("age\":28"));
    assertTrue(mergedJson.contains("occupation\":\"Engineer\""));
}

(四)merge(Object originObject, Object currentObject) 方法

该方法能够处理对象类型的输入。如果输入是字符串,则直接调用相应的字符串版本的合并方法;否则,将对象转换为 JSON 字符串后进行合并。

测试示例:

@Test
void testMergeWithObjects() {
    Object originObject = "{\"fruit\":\"Apple\",\"quantity\":5}";
    Object currentObject = "{\"quantity\":10,\"color\":\"Red\"}";
    ModelMergeUtil modelMergeUtil = new ModelMergeUtil();

    String mergedJson = modelMergeUtil.merge(originObject, currentObject);

    assertTrue(mergedJson.contains("fruit\":\"Apple\""));
    assertTrue(mergedJson.contains("quantity\":10"));
    assertTrue(mergedJson.contains("color\":\"Red\""));
}

三、总结

ModelMergeUtil 工具类通过多种 merge 方法的实现,为我们提供了灵活且高效的数据合并解决方案,使得在处理对象和数据的合并操作时更加便捷和可靠。希望以上说明和测试示例能够帮助您更好地理解和使用 ModelMergeUtil 工具类。

ModelMergeUtil 工具类的依赖gson。

<dependency>
	<groupId>com.google.code.gson</groupId>
    <artifactId>gson</artifactId>
    <version>2.8.8</version>
</dependency>

ModelMergeUtil 工具类的完整代码如下:

package com.fhey.common.utils;

import com.ecwid.consul.json.GsonFactory;
import com.google.gson.Gson;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.springframework.util.ObjectUtils;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;

/**
 * @author: fhey
 * @create: 2021-02-22 13:53
 * @description: 对象合并工具类
 */
@Slf4j
public class ModelMergeUtil2 {
    /**
     * 将当前对象与原始对象比较,并将数据合并到原始对象中
     *
     * @param originJsonStr
     * @param currentJsonStr
     * @param clazz
     */
    public static <T> T merge(String originJsonStr, String currentJsonStr, Class<T> clazz) {
        String mergeStr = merge(originJsonStr, currentJsonStr);
        T object =  GsonFactory.getGson().fromJson(mergeStr, clazz);
        return object;
    }

    /**
     * 将当前对象与原始对象比较,并将数据合并到原始对象中
     *
     * @param originObject
     * @param currentObject
     * @param clazz
     */
    public static <T> T merge(T originObject, T currentObject, Class<T> clazz) {
        String mergeStr = merge(originObject, currentObject);
        T object = GsonFactory.getGson().fromJson(mergeStr, clazz);
        return object;
    }

    /**
     * 将当前对象与原始对象比较,并将数据合并到原始对象中
     *
     * @param originJsonStr
     * @param currentJsonStr
     */
    public static String merge(String originJsonStr, String currentJsonStr) {
        log.info("merge's origin ---> {}", originJsonStr);
        log.info("merge's current ---> {}", currentJsonStr);

        Gson gson = GsonFactory.getGson();
        Map<String, Object> originMap = StringUtils.isBlank(originJsonStr)
                ? new HashMap<>()
                : gson.fromJson(originJsonStr, Map.class);
        Map<String, Object> currentMap = StringUtils.isBlank(currentJsonStr)
                ? new HashMap<>()
                : gson.fromJson(currentJsonStr, Map.class);
        Map<String, Object> newMap = merge(originMap, currentMap);
        String merge = gson.toJson(newMap);
        log.info("merge's result ---> {}", merge);
        return merge;
    }

    /**
     * 将当前对象与原始对象比较,并将数据合并到原始对象中
     *
     * @param originObject
     * @param currentObject
     */
    public static String merge(Object originObject, Object currentObject) {
        if (originObject instanceof String && currentObject instanceof String) {
            return merge(originObject.toString(), currentObject.toString());
        }
        Gson gson = GsonFactory.getGson();
        String originJsonStr = ObjectUtils.isEmpty(originObject) ? StringUtils.EMPTY : gson.toJson(originObject);
        String currentJsonStr = ObjectUtils.isEmpty(currentObject) ? StringUtils.EMPTY : gson.toJson(currentObject);
        return merge(originJsonStr, currentJsonStr);
    }



    /**
     * 将当前Map与原始Map比较,并将数据统一存在原始Map中
     *
     * @param originMap
     * @param currentMap
     */
    private static Map<String, Object> merge(Map<String, Object> originMap, Map<String, Object> currentMap) {
        for (Iterator<Map.Entry<String, Object>> it = currentMap.entrySet().iterator(); it.hasNext(); ) {
            Map.Entry<String, Object> item = it.next();
            String key = item.getKey();
            Object newValue = item.getValue();
            if (originMap.containsKey(key)) {
                Object oldValue = originMap.get(key);
                if (!newValue.equals(oldValue)) {
                    originMap.put(key, newValue);
                }
            } else {
                originMap.put(key, newValue);
            }
        }
        return originMap;
    }
}
  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
以下是一个简单的Java工具类,可以使用EasyExcel库将数据填充到Excel中,并合并具有相同属性的行。 ```java import com.alibaba.excel.EasyExcel; import com.alibaba.excel.ExcelWriter; import com.alibaba.excel.write.merge.AbstractMergeStrategy; import com.alibaba.excel.write.merge.LoopMergeStrategy; import com.alibaba.excel.write.metadata.WriteSheet; import com.alibaba.excel.write.metadata.WriteWorkbook; import java.util.ArrayList; import java.util.List; import java.util.Map; import java.util.stream.Collectors; /** * EasyExcel填充数据并合并相同属性的工具类 */ public class EasyExcelUtil { /** * 填充数据并合并相同属性的行 * * @param filePath 文件路径 * @param sheetName 工作表名称 * @param header 头部 * @param data 数据 * @param mergeIndex 需要合并的列的索引 */ public static void fillAndMerge(String filePath, String sheetName, List<String> header, List<List<String>> data, int mergeIndex) { // 创建一个Excel写工具 ExcelWriter writer = EasyExcel.write(filePath).build(); // 创建一个工作表 WriteSheet sheet = EasyExcel.writerSheet(sheetName).build(); // 将数据按照相同的属性分组 Map<String, List<List<String>>> groupMap = groupByProperty(data, mergeIndex); // 遍历分组后的数据,将每个分组写入Excel中 groupMap.forEach((property, groupData) -> { // 写入头部 writer.writeHeader(header, sheet); // 写入数据 writer.write(groupData, sheet); // 合并相同属性的行 AbstractMergeStrategy mergeStrategy = new LoopMergeStrategy(property, mergeIndex); mergeStrategy.merge(sheet, writer); }); // 关闭Excel写工具 writer.finish(); } /** * 将数据按照指定的属性分组 * * @param data 数据 * @param mergeIndex 需要合并的列的索引 * @return 分组后的数据,Map的键为属性值,值为数据列表 */ private static Map<String, List<List<String>>> groupByProperty(List<List<String>> data, int mergeIndex) { return data.stream().collect(Collectors.groupingBy(row -> row.get(mergeIndex))); } } ``` 使用示例: ```java public class Main { public static void main(String[] args) { // 准备数据 List<String> header = new ArrayList<>(); header.add("姓名"); header.add("年龄"); header.add("性别"); List<List<String>> data = new ArrayList<>(); data.add(Arrays.asList("张三", "20", "男")); data.add(Arrays.asList("李四", "22", "男")); data.add(Arrays.asList("王五", "20", "女")); data.add(Arrays.asList("赵六", "22", "女")); // 填充数据并合并相同属性的行 EasyExcelUtil.fillAndMerge("test.xlsx", "Sheet1", header, data, 2); } } ``` 在这个示例中,我们将数据按照性别分组,并将具有相同性别的行合并一起。因此,输出的Excel文件将具有两行,每行具有两个单元格,显示相同性别的人的姓名和年龄。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

知北游z

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值