EasyExcel导入导出

一,工具类

复制代码
import cn.hutool.json.JSONUtil;
import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.read.listener.PageReadListener;
import com.alibaba.excel.util.MapUtils;
import com.alibaba.excel.write.style.column.LongestMatchColumnWidthStyleStrategy;
import org.springframework.web.multipart.MultipartFile;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.net.URLEncoder;
import java.util.List;
import java.util.Map;

public class ExcelUtils <T> {


    /**
     * 文件下载并且失败的时候返回json(默认失败了会返回一个有部分数据的Excel)
     *
     * @since 2.1.1
     */
    public static <T> void excelDownload(HttpServletResponse response, String fileName, Class clazz, List<T> data) throws IOException {
        // 这里注意 有同学反应使用swagger 会导致各种问题,请直接用浏览器或者用postman
        try {
            response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
            response.setCharacterEncoding("utf-8");
            // 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系
            response.setHeader("Content-disposition","attachment;filename*=utf-8''"+ URLEncoder.encode(fileName,"UTF-8").replaceAll("\\+","%20")+".xlsx");
            // LongestMatchColumnWidthStyleStrategy 自动调节单元格宽度策略
            EasyExcel.write(response.getOutputStream(),clazz).autoCloseStream(Boolean.FALSE).registerWriteHandler(new LongestMatchColumnWidthStyleStrategy()).sheet(fileName).doWrite(data);
        } catch (Exception e) {
            // 重置response
            response.reset();
            response.setContentType("application/json");
            response.setCharacterEncoding("utf-8");
            Map<String, String> map = MapUtils.newHashMap();
            map.put("status", "failure");
            map.put("message", "下载文件失败" + e.getMessage());
            response.getWriter().println(JSONUtil.toJsonStr(map));
        }
    }


    public static <T> void excelRead(MultipartFile excel, Class clazz , List<T> list) throws IOException {
        // 这里默认每次会读取100条数据 然后返回过来 直接调用使用数据就行
        // 具体需要返回多少行可以在`PageReadListener`的构造函数设置
        EasyExcel.read(excel.getInputStream(), clazz, new PageReadListener<T>(dataList -> {
            list.addAll(dataList);
        })).sheet().doRead();
    }
}

二,接口

1,下载模板接口

a, 模板类

复制代码
@Data
@EqualsAndHashCode
public class ParkingBerthTemplateVO{

    @ExcelProperty(value = "停车场名称*",index = 0)
    private String parkingName;

    @ExcelProperty(value = "泊位编码*",index = 1)
    private String berthCode;

    @ExcelProperty(value = "设备编码*",index = 2)
    private String deviceCode;

}

b, 接口

复制代码
        @ApiOperation(value = "下载导入模板", notes = "下载导入模板")
        @GetMapping("template")
        public void downloadTemplate(HttpServletResponse response) throws IOException {
                String fileName = "导入模板";
                ExcelUtils.excelDownload(response, fileName, ParkingBerthTemplateVO.class, null);
        }

2,导入接口

复制代码
        @ApiOperation(value = "导入", notes = "导入")
        @PostMapping("import")
        public Result<Boolean> berthImport(MultipartFile excel ) throws IOException {

                List<ParkingBerthTemplateVO> voList = new ArrayList<>();
                ExcelUtils.excelRead(excel,ParkingBerthTemplateVO.class, voList);

                Assert.isFalse(CollectionUtil.isEmpty(voList), "文件不能为空");

                 // 保存逻辑
               // parkingBerthService.berthImport(voList);

                return Result.ok();
        }

3,导出接口

a,导出vo类

复制代码
/**
 * 停车订单
 */
@Data
@SuperBuilder
@NoArgsConstructor
@Accessors(chain = true)
@ExcelIgnoreUnannotated
public class OrderParkingExportDTO {

    @ColumnWidth(10)
    @ExcelProperty(value = "ID" ,index = 0)
    private Long id;
    
    @ExcelProperty(value = "供应商ID",index = 1)
    private Long tenantId;

//    @ColumnWidth(100)
    @ExcelProperty(value = "订单号",index = 2)
    private String orderCode;

    @ExcelProperty(value = "停车场ID",index = 3)
    private Long parkingId;

    @ExcelProperty(value = "停车场名称",index = 4 )
    private String parkingName;

    @ExcelProperty(value = "客户ID",index = 5 )
    private Long customerId;

    @ExcelProperty(value = "无牌/有牌",index = 6 )
    private String hasPlateNoString;

    @ExcelProperty(value = "车牌",index = 7 )
    private String plateNo;

    private PlateColor plateColor;
    @ExcelProperty(value = "车牌颜色",index = 8 )
    private String plateColorString;

    public void dataProcessor(){
        if(hasPlateNo!= null){
            hasPlateNoString = hasPlateNo == true ? "有牌" : "无牌";
        }
        if(plateColor!= null){
            plateColorString = plateColor.getDesc();
        }
    }

}

b, 接口

复制代码
        @ApiOperation(value = "列表导出", notes = "列表导出")
        @PostMapping("download")
        public void download(HttpServletResponse response,@RequestBody OrderParkingQueryVO vo, @ApiIgnore LoginSysUser loginSysUser) throws IOException {

                OrderParkingQueryDTO dto = OrderParkingConverter.INSTANCE.orderParking(vo, loginSysUser);
                List<OrderParking> list = orderParkingService.list(dto);
                List<OrderParkingExportDTO> data =  OrderParkingConverter.INSTANCE.entityToExportDto(list);
                data.forEach(item -> item.dataProcessor());
                String fileName = "列表导出";
                ExcelUtils.excelDownload(response,fileName,OrderParkingExportDTO.class,data);
        }
相关推荐
想躺平的咸鱼干6 分钟前
RabbitMQ 基础
java·分布式·rabbitmq·idea·amqp·消息转换器·交换机模型
Monly217 分钟前
RabbitMQ:延时消息(死信交换机、延迟消息插件)
java·rabbitmq·java-rabbitmq
寒士obj1 小时前
Spring容器Bean的创建流程
java·后端·spring
掉鱼的猫1 小时前
Spring AOP 与 Solon AOP 有什么区别?
java·spring
不是光头 强2 小时前
axure chrome 浏览器插件的使用
java·chrome
笨蛋不要掉眼泪2 小时前
Spring Boot集成腾讯云人脸识别实现智能小区门禁系统
java·数据库·spring boot
桃源学社(接毕设)2 小时前
云计算下数据隐私保护系统的设计与实现(LW+源码+讲解+部署)
java·云计算·毕业设计·swing·隐私保护
用户0332126663672 小时前
Java 将 Excel 转换为 HTML:解锁数据在线展示的无限可能
java·excel
字节跳跃者3 小时前
SpringBoot + MinIO + kkFile 实现文件预览,这样操作更安全!
java·后端·程序员
似水流年流不尽思念3 小时前
Spring 的声明式事务在多线程的场景当中会失效,该怎么解决呢?
后端·spring·面试