java easyexcel 写入数据到excel中的多个sheet中

本文介绍了如何使用EasyExcel在Spring MVC控制器中实现批量下载上传结果的功能,涉及了HTTP请求处理、参数校验、Excel文件生成及定制单元格写入策略。服务类详细展示了如何通过EasyExcel操作数据并设置列宽,以及CustomCellWriteHandler用于处理Excel样式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

controller方法:

@ApiOperation("下载导入结果")
    @RequestMapping(value = "/downloadUploadResut", method = RequestMethod.POST)
    public void batchDownload(HttpServletRequest request,
                              HttpServletResponse response,
                              @RequestBody  DownloadAssetResultDto  downloadAssetResultDto) throws Exception {

        if(downloadAssetResultDto==null || downloadAssetResultDto.getUploadId()==null){
            throw  new RRException("上传数据ID为空,请先上传数据");
        }

        request.setCharacterEncoding("UTF-8");
        String prefix=".xlsx";
        String fileName="uploadResult";
        String userAgent = request.getHeader("User-Agent");
        String     downLoadPath = URLDecoder.decode(fileName, "UTF-8");
        System.out.println(downLoadPath);
        try {

            response.setContentType("application/vnd.ms-excel");
            fileName = URLEncoder.encode(fileName, "ISO8859-1");
            response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xlsx");
            response.setHeader("filename",fileName);
            Integer uploadId = downloadAssetResultDto.getUploadId();
            downloadAssetService.downloadUploadResut(response,uploadId);


        } catch (Exception e) {
            e.printStackTrace();
        }

    }

service业务类实现方法:

@Override
    public void downloadUploadResut(HttpServletResponse response,Integer  uploadId) {
        ExcelWriter excelWriter = null;
        try {
            CustomCellWriteHandler customCellWriteHandler = new CustomCellWriteHandler();
            excelWriter = EasyExcel.write(response.getOutputStream()).build();
           
            List<BizObjectModeExport> bizObjectUploadData =bizObjectUploadData(uploadId);
            //创建一个sheet
            WriteSheet writeSheet = EasyExcel.writerSheet( "sheet1").head(BizObjectModeExport.class).registerWriteHandler(customCellWriteHandler).build();
            excelWriter.write(bizObjectUploadData, writeSheet);


            
            List<LogicEntityModelExport> logicEntityUploadData = logicEntityUploadData(uploadId);
            //创建一个新的sheet
            writeSheet = EasyExcel.writerSheet("sheet2").head(LogicEntityModelExport.class).registerWriteHandler(customCellWriteHandler).build();
            excelWriter.write(logicEntityUploadData, writeSheet);

            
            List<AttributeModelExport> attributeUploadData = attributeUploadData(uploadId);
            writeSheet = EasyExcel.writerSheet("sheet3").head(AttributeModelExport.class).registerWriteHandler(customCellWriteHandler).build();
            excelWriter.write(attributeUploadData, writeSheet);


           
            List<TechMetadataModelExport> techMetadataUploadData = techMetadataUploadData(uploadId);
            writeSheet = EasyExcel.writerSheet("shee4").head(TechMetadataModelExport.class).registerWriteHandler(customCellWriteHandler).build();
            excelWriter.write(techMetadataUploadData, writeSheet);



          /*
            // 这里需要设置不关闭流
            EasyExcel.write(response.getOutputStream(), BizObjectModeExport.class)
                    .registerWriteHandler(new CustomCellWriteHandler())
                    .autoCloseStream(Boolean.TRUE).sheet("sheet")
                    .doWrite(bizObjectUploadData);*/
        } catch (Exception e) {
            // 重置response
            response.reset();
            response.setContentType("application/json");
            response.setCharacterEncoding("utf-8");
            Map<String, String> map = new HashMap<String, String>();
            map.put("flag", "failure");
            map.put("message", "下载文件失败" + e.getMessage());
            try {
                response.getWriter().println(JSON.toJSONString(map));
            } catch (IOException e1) {
                e1.printStackTrace();
            }
        }finally{
            if(excelWriter!=null){
                excelWriter.finish();
            }

        }
    }

CustomCellWriteHandler.java

package cn.getech.data.manager.service.impl;
import com.alibaba.excel.enums.CellDataTypeEnum;
import com.alibaba.excel.metadata.CellData;
import com.alibaba.excel.metadata.Head;
import com.alibaba.excel.util.CollectionUtils;
import com.alibaba.excel.write.metadata.holder.WriteSheetHolder;
import com.alibaba.excel.write.style.column.AbstractColumnWidthStyleStrategy;
import org.apache.poi.ss.usermodel.Cell;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * @ClassName CustomCellWriteHandler
 * @Description TODO
 * @Author Getech
 * @Date 2020/11/13 16:33
 */
public class CustomCellWriteHandler  extends AbstractColumnWidthStyleStrategy {

    private Map<Integer, Map<Integer, Integer>> CACHE = new HashMap<>();

    @Override
    protected void setColumnWidth(WriteSheetHolder writeSheetHolder, List<CellData> cellDataList, Cell cell, Head head, Integer relativeRowIndex, Boolean isHead) {
        boolean needSetWidth = isHead || !CollectionUtils.isEmpty(cellDataList);
        if (needSetWidth) {
            Map<Integer, Integer> maxColumnWidthMap = CACHE.get(writeSheetHolder.getSheetNo());
            if (maxColumnWidthMap == null) {
                maxColumnWidthMap = new HashMap<>();
                CACHE.put(writeSheetHolder.getSheetNo(), maxColumnWidthMap);
            }

            Integer columnWidth = this.dataLength(cellDataList, cell, isHead);
            if (columnWidth >= 0) {
                if (columnWidth > 255) {
                    columnWidth = 255;
                }

                Integer maxColumnWidth = maxColumnWidthMap.get(cell.getColumnIndex());
                if (maxColumnWidth == null || columnWidth > maxColumnWidth) {
                    maxColumnWidthMap.put(cell.getColumnIndex(), columnWidth);
                    writeSheetHolder.getSheet().setColumnWidth(cell.getColumnIndex(), columnWidth * 256);
                }

            }
        }
    }

    private Integer dataLength(List<CellData> cellDataList, Cell cell, Boolean isHead) {
        if (isHead) {
            return cell.getStringCellValue().getBytes().length;
        } else {
            CellData cellData = cellDataList.get(0);
            CellDataTypeEnum type = cellData.getType();
            if (type == null) {
                return -1;
            } else {
                switch (type) {
                    case STRING:
                        return cellData.getStringValue().getBytes().length;
                    case BOOLEAN:
                        return cellData.getBooleanValue().toString().getBytes().length;
                    case NUMBER:
                        return cellData.getNumberValue().toString().getBytes().length;
                    default:
                        return -1;
                }
            }
        }
    }
}

其中一个excelmodel.java

package com.cwp.vo;
import com.alibaba.excel.annotation.ExcelProperty;
import lombok.Data;

@Data
public class BizObjectModel {


   
    @ExcelProperty(value = "编码",order = 1)
    private String code;


   
    @ExcelProperty(value = "名称",order = 5)
    private String name;

   
}

 引入alibaba easyexcel依赖片段:

 <!-- alibaba excel依赖 -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <version>2.2.6</version>
            <exclusions>
                <exclusion>
                    <artifactId>cglib</artifactId>
                    <groupId>cglib</groupId>
                </exclusion>
            </exclusions>
        </dependency>

 

### Java 使用 EasyExcel导出包含多个 SheetExcel 文件 以下是基于 `EasyExcel` 实现多 Sheet 导出的具体方法。通过配置不同的数据集并将其写入不同 Sheet 中,可以实现复杂的数据结构导出。 #### 1. 添加依赖 首先需要引入 `EasyExcel` 的 Maven 或 Gradle 依赖: ```xml <!-- Maven --> <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>3.0.5</version> <!-- 版本号可能有所不同,请根据实际情况调整 --> </dependency> ``` 或者对于 Gradle 用户: ```gradle // Gradle implementation 'com.alibaba:easyexcel:3.0.5' ``` --- #### 2. 编写代码示例 下面是一个完整的代码示例,展示如何使用 `EasyExcel` 创建一个多 SheetExcel 文件: ```java import com.alibaba.excel.EasyExcel; import java.util.ArrayList; import java.util.List; public class MultiSheetExport { public static void main(String[] args) { String fileName = "multi-sheet-example.xlsx"; // 数据准备 List<UserData> userDataList = prepareUserData(); List<OrderData> orderDataList = prepareOrderData(); // 构建 writer 并设置参数 try (var excelWriter = EasyExcel.write(fileName).build()) { // 写入第一个 Sheet WriteSheet userSheet = EasyExcel.writerSheet(0, "用户信息").head(UserData.class).build(); excelWriter.write(userDataList, userSheet); // 写入第二个 Sheet WriteSheet orderSheet = EasyExcel.writerSheet(1, "订单信息").head(OrderData.class).build(); excelWriter.write(orderDataList, orderSheet); } System.out.println("多 Sheet 导出完成!"); } private static List<UserData> prepareUserData() { var userList = new ArrayList<UserData>(); userList.add(new UserData("张三", 28)); userList.add(new UserData("李四", 34)); return userList; } private static List<OrderData> prepareOrderData() { var orderList = new ArrayList<OrderData>(); orderList.add(new OrderData("A001", 100.0)); orderList.add(new OrderData("B002", 200.0)); return orderList; } } class UserData { @com.alibaba.excel.annotation.ExcelProperty("姓名") private String name; @com.alibaba.excel.annotation.ExcelProperty("年龄") private int age; public UserData() {} public UserData(String name, int age) { this.name = name; this.age = age; } // Getter and Setter methods... } class OrderData { @com.alibaba.excel.annotation.ExcelProperty("订单编号") p
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

成伟平2022

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

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

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

打赏作者

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

抵扣说明:

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

余额充值