看了一下demo,如果把前面的两篇都看过了,跑了跑demo,这里没什么需要再解释了.直接上个springboot的demo.先运行下载,再把下载的文件上传,试了一下.没啥问题.真心好用.给easyexcel 100分.感谢阿里的各位大佬.
demo下载地址 : https://download.csdn.net/download/hjl21/12701838
直接用官网的demo,
/** * 文件下载(失败了会返回一个有部分数据的Excel) *
1. 创建excel对应的实体对象 参照{@link DownloadData}
*
2. 设置返回的 参数
*
3. 直接写,这里注意,finish的时候会自动关闭OutputStream,当然你外面再关闭流问题不大
*/ @GetMapping("download") public void download(HttpServletResponse response) throws IOException { // 这里注意 有同学反应使用swagger 会导致各种问题,请直接用浏览器或者用postman response.setContentType("application/vnd.ms-excel"); response.setCharacterEncoding("utf-8"); // 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系 String fileName = URLEncoder.encode("测试", "UTF-8"); response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xlsx"); EasyExcel.write(response.getOutputStream(), DownloadData.class).sheet("模板").doWrite(data()); } /** * 文件上传 *
1. 创建excel对应的实体对象 参照{@link UploadData}
*
2. 由于默认一行行的读取excel,所以需要创建excel一行一行的回调监听器,参照{@link UploadDataListener}
*
3. 直接读即可
*/ @PostMapping("upload") @ResponseBody public String upload(MultipartFile file) throws IOException { EasyExcel.read(file.getInputStream(), UploadData.class, new UploadDataListener(uploadDAO)).sheet().doRead(); return "success"; }