EasyExcel自定义字段对象转换器支持转换实体和集合实体

文章目录

      • 1. 实现ObjectConverter
      • 2. 使用
      • 3. 测试
          • 3.2 导出excel
          • 3.1 导入excel

1. 实现ObjectConverter

package com.tophant.cloud.common.excel.converters;

import cn.hutool.json.JSONUtil;
import com.alibaba.excel.converters.Converter;
import com.alibaba.excel.enums.CellDataTypeEnum;
import com.alibaba.excel.metadata.GlobalConfiguration;
import com.alibaba.excel.metadata.data.ReadCellData;
import com.alibaba.excel.metadata.data.WriteCellData;
import com.alibaba.excel.metadata.property.ExcelContentProperty;

import java.lang.reflect.Type;

/**
 * 对象转换器
 * 支持转换字段类型为自定义实体,List<实体>,List,Map等
 *
 * @author wan.fei
 * @date 2023/08/26
 */
public class ObjectConverter implements Converter {

    @Override
    public Class supportJavaTypeKey() {
        return Object.class;
    }

    @Override
    public CellDataTypeEnum supportExcelTypeKey() {
        return CellDataTypeEnum.STRING;
    }

    /**
     * 转换从excel中读取的数据为ExcelVO中定义的字段类型(自定义实体,List<实体>,List,Map等)
     *
     * @param cellData            单元格数据
     * @param contentProperty     内容属性
     * @param globalConfiguration 全局配置
     * @return {@link Object}
     * @throws Exception 异常
     */
    @Override
    public Object convertToJavaData(ReadCellData cellData, ExcelContentProperty contentProperty, GlobalConfiguration globalConfiguration) throws Exception {
        String stringValue = cellData.getStringValue();
        // 获取定义的实体字段的实际类型,包括泛型参数信息
        Type genericType = contentProperty.getField().getGenericType();
        return JSONUtil.toBean(stringValue, genericType, false);
    }

    /**
     * 转换数据为json字符串,写入到excel文件
     *
     * @param value               价值
     * @param contentProperty     内容属性
     * @param globalConfiguration 全局配置
     * @return {@link WriteCellData}<{@link ?}>
     * @throws Exception 异常
     */
    @Override
    public WriteCellData convertToExcelData(Object value, ExcelContentProperty contentProperty,
                                               GlobalConfiguration globalConfiguration) throws Exception {
        String json = JSONUtil.toJsonStr(value);
        return new WriteCellData(json);
    }
}
 
  

2. 使用

EasyExcel自定义字段对象转换器支持转换实体和集合实体_第1张图片

3. 测试

3.2 导出excel

手动添加一些数据
EasyExcel自定义字段对象转换器支持转换实体和集合实体_第2张图片
导出
EasyExcel自定义字段对象转换器支持转换实体和集合实体_第3张图片
写入excel转换成功

3.1 导入excel

将上面生成的excel文件导入
EasyExcel自定义字段对象转换器支持转换实体和集合实体_第4张图片
读取excel数据并转换成功

你可能感兴趣的:(easyexcel,java)