导出效果
ID | 名称 | 简称 | 代次 | 描述 | 类型 |
7 | 海兰褐蛋鸡 | HLB | 商品代 | 海兰褐商品代蛋鸡 | 蛋鸡 |
8 | 海兰褐父母代 | HLBPS | 父母代 | 海兰褐父母代蛋鸡 | 蛋种 |
9 | AA父母代 | 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);