EasyExcel复杂表头数据导入

表头示例

在这里插入图片描述

导入代码

    @Override
    public void importExcel(InputStream inputStream) {
        ItemExcelListener itemExcelListener = new ItemExcelListener();
        EasyExcel.read(inputStream, ImportItem.class, itemExcelListener).headRowNumber(2).sheet().doRead();
    }
@Slf4j
public class ItemExcelListener extends AnalysisEventListener<ImportItem> {
    /**
     * 定义100条数据存储一次,然后清理list,方便内存回收
     */
    private static final int BATCH_COUNT = 300;
    /**
     * 记录导入的总记录数
     */
    private Long listSize = 0L;
    /**
     * 缓存的数据
     */
    private List<ImportItem> cachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);

    //标记处理第一行表头
    private boolean firstRowProcessed = true;

    private HashMap<Integer, HashMap<String,String>> dynamicInfoList;

    /**
     * 解析每一行表头数据时调用
     */
    @Override
    public void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) {
        // 读取表头数据并构造HashMap
        if (firstRowProcessed){
            HashMap<Integer, HashMap<String, String>> infoList = new HashMap<>();
            for (Map.Entry<Integer, String> entry : headMap.entrySet()){
                Integer key = entry.getKey();
                String value = entry.getValue();
                if (!Objects.equals(value, "固定数据")){
                    infoList.put(key,null);
                }
            }
            dynamicInfoList = infoList;
            firstRowProcessed = false;
        }else {
            for (Map.Entry<Integer, String> entry : headMap.entrySet()){
                HashMap<String, String> info = new HashMap<>();
                Integer key = entry.getKey();
                String value = entry.getValue();
                if (dynamicInfoList.containsKey(key)){
                    info.put(value,null);
                    dynamicInfoList.replace(key,info);
                }
            }
        }
    }

    /**
     * 每解析一条数据都会调用一次
     */
    @Override
    public void invoke(ImportItem importItem, AnalysisContext analysisContext) {
        // 获取实体类中不匹配的数据
        ReadRowHolder readRowHolder = analysisContext.readRowHolder();
        Map<Integer, Cell> cellMap = readRowHolder.getCellMap();
        JSONObject dynamicInformation = new JSONObject();
        for (Map.Entry<Integer, Cell> entry : cellMap.entrySet()){
            Integer key = entry.getKey();
            Cell entryValue = entry.getValue();
            if (dynamicInfoList.containsKey(key)){
                String string = JSON.toJSONString(entryValue);
                JSONObject jsonObject = JSON.parseObject(string);
                String value = jsonObject.getString("stringValue");
                HashMap<String, String> info = dynamicInfoList.get(key);
                for (String attribute : info.keySet()) {
                    dynamicInformation.put(attribute,value);
                }
            }
        }
        cachedDataList.add(importItem);
        // 达到BATCH_COUNT了,需要去存储一次数据库,防止数据几万条数据在内存,容易OOM
        if (cachedDataList.size() >= BATCH_COUNT) {
            saveData();
            // 存储完成清理 list
            cachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);
        }
    }

    /**
     * 所有数据解析完成后调用
     */
    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {
        if (!cachedDataList.isEmpty()){
            saveData();
            // 存储完成清理 list
            cachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);
        }
    }

    public void saveData(){
        //将数据存入数据库
    }


}

数据导出

参考文章:EasyExcel动态复杂表头导出方法

  • 7
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
对于复杂表头的导出,EasyExcel是一个非常方便的Java库。你可以按照以下步骤进行操作: 1. 导入EasyExcel依赖:在你的项目中,添加EasyExcel的Maven或Gradle依赖。 2. 创建表头样式:使用EasyExcel提供的样式类,如`com.alibaba.excel.write.style.column.SimpleColumnWidthStyleStrategy`,可根据列宽自动调整。你还可以自定义样式,如字体、颜色等。 3. 定义数据模型:创建一个Java类,用于表示导出数据的模型。每个字段对应一列数据。 4. 准备数据:从数据库或其他数据源获取要导出的数据,并将其封装到定义好的数据模型中。 5. 创建导出任务:使用EasyExcel提供的`com.alibaba.excel.EasyExcel.write()`方法创建一个导出任务。传入要导出的数据集合、要导出的数据模型类以及导出文件的路径。 6. 设置表头:使用EasyExcel提供的`com.alibaba.excel.write.metadata.style.WriteCellStyle`类,可以设置表头的样式。 7. 执行导出:调用导出任务的`sheet()`方法,设置表格名称和表头行数。然后调用`doWrite()`方法执行导出。导出的过程是逐行写入,并自动处理分页和大数据量导出。 下面是一个示例代码片段,演示了如何使用EasyExcel导出复杂表头: ``` // 导出数据 List<YourDataModel> dataList = getDataFromDataSource(); // 创建导出任务 String exportFilePath = "path/to/export/file.xlsx"; ExcelWriter excelWriter = EasyExcel.write(exportFilePath, YourDataModel.class).build(); // 设置表头样式 WriteCellStyle headStyle = new WriteCellStyle(); // 设置样式属性,如字体、颜色等 // 执行导出 excelWriter.sheet().head(headStyle).doWrite(dataList); // 关闭资源 excelWriter.finish(); ``` 这样,你就可以使用EasyExcel实现复杂表头的导出了。希望对你有帮助!如有更多问题,请继续提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值