FastExcel - EasyExcel停更后原作者平替
1、官方网站及文档
https://idev.cn/fastexcel/zh-CN/docs
2、pom
<dependency>
<groupId>cn.idev.excel</groupId>
<artifactId>fastexcel</artifactId>
<version>1.0.0</version>
</dependency>
3、使用方法同EasyExcel
import cn.idev.excel.EasyExcel; import lombok.extern.slf4j.Slf4j; import javax.servlet.http.HttpServletResponse; import java.io.*; import java.net.URLEncoder; import java.util.List; @Slf4j public class EasyExcelUtil { public static <T> List<T> read(String filePath, final Class<?> clazz) { File f = new File(filePath); try (FileInputStream fis = new FileInputStream(f)) { return read(fis, clazz); } catch (FileNotFoundException e) { log.error("文件{}不存在", filePath, e); } catch (IOException e) { log.error("文件读取出错", e); } return null; } public static <T> List<T> read(InputStream inputStream, final Class<?> clazz) { // 有个很重要的点 DataListener 不能被spring管理,要每次读取excel都要new,然后里面用到spring可以构造方法传进去 DataListener<T> listener = new DataListener<>(); // 这里 需要指定读用哪个class去读,然后读取第一个sheet 文件流会自动关闭 EasyExcel.read(inputStream, clazz, listener).sheet().doRead(); return listener.getRows(); } public static void write(String outFile, List<?> list) { Class<?> clazz = list.get(0).getClass(); // 新版本会自动关闭流,不需要自己操作 EasyExcel.write(outFile, clazz).sheet().doWrite(list); } public static void write(String outFile, List<?> list, String sheetName) { Class<?> clazz = list.get(0).getClass(); // 新版本会自动关闭流,不需要自己操作 EasyExcel.write(outFile, clazz).sheet(sheetName).doWrite(list); } public static void write(OutputStream outputStream, List<?> list, String sheetName) { Class<?> clazz = list.get(0).getClass(); // 新版本会自动关闭流,不需要自己操作 // sheetName为sheet的名字,默认写第一个sheet EasyExcel.write(outputStream, clazz).sheet(sheetName).doWrite(list); } /** * 文件下载(失败了会返回一个有部分数据的Excel),用于直接把excel返回到浏览器下载 */ public static void download(HttpServletResponse response, List<?> list, String sheetName) throws IOException { Class<?> clazz = list.get(0).getClass(); // 这里注意 有同学反应使用swagger 会导致各种问题,请直接用浏览器或者用postman response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"); response.setCharacterEncoding("utf-8"); // 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系 String fileName = URLEncoder.encode(sheetName, "UTF-8").replaceAll("\\+", "%20"); response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx"); EasyExcel.write(response.getOutputStream(), clazz).sheet(sheetName).doWrite(list); } }
import cn.idev.excel.annotation.ExcelIgnore; import cn.idev.excel.annotation.ExcelProperty; import cn.idev.excel.annotation.write.style.ColumnWidth; import lombok.Data; @Data public class CarInfoExcel { @ExcelProperty("车辆ID") @ColumnWidth(150) private Long carId; @ExcelProperty("自编号") @ColumnWidth(100) private String carZbh; @ExcelProperty("车牌号") private String carNo; @ExcelIgnore private Long cartypeId; @ExcelIgnore private Long cardjId; }
import cn.idev.excel.context.AnalysisContext; import cn.idev.excel.event.AnalysisEventListener; import lombok.extern.slf4j.Slf4j; import java.util.ArrayList; import java.util.List; /** * excel解析过程监听器 */ @Slf4j public class DataListener<T> extends AnalysisEventListener<T> { private final List<T> rows = new ArrayList<>(); @Override public void invoke(T t, AnalysisContext analysisContext) { rows.add(t); } @Override public void doAfterAllAnalysed(AnalysisContext context) { log.info("doAfterAllAnalysed => {}", rows.size()); } public List<T> getRows() { return rows; } }
4、excel转pdf
FastExcel 支持将 Excel 文件转换为 PDF 文件。FastExcel 将Excel转为Pdf 底层依赖于Apache POI和 itext-pdf。受限于itext-pdf的许可证,请确保您的使用符合itext-pdf的许可证。 后续 FastExcel 将支持更多的PDF转换功能。替换itext-pdf。
FastExcel.convertToPdf(new File("excelFile"),new File("pdfFile"),null,null);
有些事情,没经历过不知道原理,没失败过不明白奥妙,没痛苦过不了解真谛。临渊羡鱼,不如退而结网!

浙公网安备 33010602011771号