若依集成easyExcel,获取字典redis缓存,使用自定义转换器

导出效果

ID名称简称代次描述类型
7海兰褐蛋鸡HLB商品代海兰褐商品代蛋鸡蛋鸡
8海兰褐父母代HLBPS父母代海兰褐父母代蛋鸡蛋种
9AA父母代AAPS父母代AA父母代test肉种

数据库实存

 使用字典

实现过程

1.domain字段上注明调用的convert类

    /** 代次 */
    @ExcelProperty(value = "代次",converter = BreBreedGenerationConverter.class)
    private String generation;

    /** 描述 */
    @ExcelProperty(value = "描述")
    private String description;

    /** 类型 */
    @ExcelProperty(value = "类型",converter = BreBreedTypeConverter.class)

2.编写convert。可以写死,这是不写死的方法,读取redis缓存,不能调用servcie 或mapper,convertToExcelData 和 convertToJavaData 这两个方法,要打开继承的converter.class,根据converter.class修改,convertToExcelData  CellData要写成WriteCellData,
convertToJavaData(CellData cellData, 改成convertToJavaData(ReadCellData cellData,

完整代码如下:

package com.ruoyi.zysoft.domain.read;

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 com.ruoyi.common.core.domain.entity.SysDictData;

import java.util.List;
import java.util.Objects;

import static com.ruoyi.common.utils.DictUtils.getDictCache;

public class BreBreedTypeConverter implements Converter<String> {
    @Override
    public Class supportJavaTypeKey()
    {
        return Integer.class;
    }

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

    @Override
    public String convertToJavaData(ReadCellData cellData, ExcelContentProperty contentProperty, GlobalConfiguration globalConfiguration)
    {
        String value="";
        String str = cellData.getStringValue();
        List<SysDictData> sysDictDataList =  getDictCache("bre_breeder_type");
        if(sysDictDataList.size() !=0){
            SysDictData sysDictData = sysDictDataList.stream().filter(s -> Objects.equals(s.getDictLabel(), str)).findFirst().orElse(null);
            if(sysDictData !=null){
                value = sysDictData.getDictValue();
            }
        }
        return  value;
    }


    @Override
    public WriteCellData convertToExcelData(String value, ExcelContentProperty contentProperty, GlobalConfiguration globalConfiguration)
    {
        String  str = "未知";
        //        Redis
        List<SysDictData> sysDictDataList =  getDictCache("bre_breeder_type");
        if(sysDictDataList.size() !=0){
            SysDictData sysDictData = sysDictDataList.stream().filter(s -> Objects.equals(s.getDictValue(), value)).findFirst().orElse(null);
            if(sysDictData !=null){
                str = sysDictData.getDictLabel();
            }
        }
        return new WriteCellData(str);
    }
}

3.非字典数据,可以仿照字典的做法

在准备导入导出前,设置缓存

SpringUtils.getBean(RedisCache.class).setCacheObject(key, dictDatas);

convert中读取缓存

Object cacheObj = SpringUtils.getBean(RedisCache.class).getCacheObject(key);

参照dictUtils.java.

SpringUtils.getBean(RedisCache.class).setCacheObject(getCacheKey(key), dictDatas);
public static String getCacheKey(String configKey)
{
    return Constants.SYS_DICT_KEY + configKey;
}
/**
 * 字典管理 cache key
 */
public static final String SYS_DICT_KEY = "sys_dict:";

 所以可以仿照这样写,再将object转List

  Object cacheObj = SpringUtils.getBean(RedisCache.class).getCacheObject("sys_dict:bre_breeder_type");
        List<SysDictData> sysDictDataList =  StringUtils.cast(cacheObj);

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值