EasyExcel生成多个excel.xlsx进行压缩导出

#java专栏#

  • 背景

通过EasyExcel进行多个ExcelTypeEnum.XLSX类型Excel写入ZIP流时会发生Stream closed异常,以下通过使用ByteArrayOutputStream字节数组输出流完成多Excel.XLSX类型的压缩并输出

1、引入相关依赖(easyexcel)

com.alibaba

easyexcel

2、定义数据模型(ExcelData)

@Data

public class ExcelData {

private String name;

private int age;

2、定义将excel文件写入指定输出流方法

private static void writerStream(OutputStream outputStream) {

ExcelWriter excelWriter =EasyExcel.write(outputStream,ExcelData.class)

.excelType(ExcelTypeEnum.XLSX).build();

WriteSheet writeSheet = EasyExcel.writerSheet("sheetName").build();

excelWriter.write(getData(), writeSheet);

excelWriter.finish();

3、执行main方法

public static void main(String[] args) throws IOException {

FileOutputStream fos = new FileOutputStream(filePath);

ZipOutputStream zos = new ZipOutputStream(fos);

ByteArrayOutputStream baos = new ByteArrayOutputStream();

writerStream(baos);

ZipEntry zipEntry = new ZipEntry("第一个excel.xlsx");

zos.putNextEntry(zipEntry);

zos.write(baos.toByteArray());

baos.reset();

ZipEntry zipEntry2 = new ZipEntry("第二个excel.xlsx");

zos.putNextEntry(zipEntry2);

baos.close();

zos.close();

  • 注意事项

    本文直接将异常处理抛出,实际应用中需要注意异常的处理

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值