JAVA POI导出excel(三):导出zip压缩包
创始人
2025-05-29 09:14:49
0

        相信在大部分的web项目中都会有导入导出Excel的需求,之前我也写过两篇导出Excel的文章,没看过的小伙伴可以去看哈,链接也给大家放出来了:

1、导出单个sheet

2、导出多个sheet

        但是在我们日常的工作中,需求往往没这么简单,可能需要将Excel打包成压缩包再导出等等。遇到类似的需求该怎么办呢,别慌,往下看。

一、pom引用

        pom文件中,添加以下依赖

        org.apache.poipoi5.2.2compileorg.apache.poipoi-ooxml5.2.2compile

 

二、工具类util

1.ExportExcelZip

package com.***.excel;import com.***.ServiceException;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;import javax.servlet.http.HttpServletResponse;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.util.Map;
import java.util.zip.ZipEntry;
import java.util.zip.ZipOutputStream;/*** @description: 导出多个Excel 压缩成ZIP*/public class ExportExcelZip {/*** 以压缩包的方式下载excel** @param response    响应* @param workbookMap* @param zipName     压缩包名称*/public static void downloadExcelForZip(HttpServletResponse response, Map workbookMap, String zipName) throws IOException {// 文件名外的双引号处理firefox的空格截断问题ZipOutputStream out = null;try {response.setContentType("application/*");response.setHeader("content-disposition", "attachment;filename=" + new String(zipName.getBytes("gb2312"), "ISO8859-1"));response.setCharacterEncoding("UTF-8");out = new ZipOutputStream(response.getOutputStream());for (String fileName : workbookMap.keySet()) {XSSFWorkbook workbook = workbookMap.get(fileName);ZipEntry entry = new ZipEntry(fileName);out.putNextEntry(entry);// 这里讲一下,workBook.write会指定关闭数据流,如果这里直接用workbook.write(out),// 下次就会抛出out已被关闭的异常,所有用ByteArrayOutputStream来拷贝一下。ByteArrayOutputStream bos = new ByteArrayOutputStream();workbook.write(bos);bos.writeTo(out);// 关闭输入流out.closeEntry();}out.flush();} catch (IOException e) {throw new ServiceException("下载文件异常"+e.getMessage(), 9000);} finally {if (out != null) {out.close();}}}}

三、相关业务代码

1.service层

    /*** 清单导出*/Map exportSales(ExportSalesDto dto);

2.impl实现类

@Overridepublic Map exportSales(ExportSalesDto dto) {List list = new ArrayList<>();ExportSalesVo exportSalesVo = new ExportSalesVo();// 表格title(表格title需要根据自己的项目需求进行修改)List titleList = Arrays.asList("单据编号", "单据序号", "客户名称", "客户税号", "客户地址电话", "客户银行账号", "客户联系方式", "商品名称", "规格型号", "计量单位", "数量", "单价", "金额", "税率", "商品编码", "使用优惠政策", "优惠政策", "零税率标识", "自行编码", "备注", "开票人", "收款人", "复核人", "折扣金额", "折扣汇总金额", "扣除额", "成品油");exportSalesVo.setTitleList(titleList);// 填充清单数据List salesList = invoiceMapper.queryInventory(dto.getInvoiceId());for (SalesListVo vo : salesList) {vo.setInvoiceNo("3000001");vo.setInvoiceSerialNum("");vo.setCustomerMobile("");vo.setUnit("吨");// 计算货物单价:金额/数量vo.setPrice(vo.getTransportMoneyReal().divide(vo.getInvoiceNum(), 5, RoundingMode.HALF_UP));vo.setRate(new BigDecimal("0.09"));vo.setGoodsCode("");vo.setIsDiscount("");vo.setDiscount("");vo.setIsZeroRate("");vo.setCustomCode("");vo.setDrawerName("");vo.setPayeeName("");vo.setReviewName("");vo.setDiscountAmount("");vo.setDiscountTotalAmount("");vo.setDeductionAmount("");vo.setRefinedOil("");}exportSalesVo.setDataList(salesList);list.add(exportSalesVo);Map workbookMap = new HashMap<>();for (ExportSalesVo vo : list) {XSSFWorkbook wk = new XSSFWorkbook();XSSFSheet sheet = wk.createSheet("清单");XSSFRow row = sheet.createRow(0);// 添加excel titleXSSFCell cell;for (int t = 0, size = vo.getTitleList().size(); t < size; t++) {cell = row.createCell(t);cell.setCellValue(vo.getTitleList().get(t));}// 在sheet中再添加1行,存放数据// 遍历将数据写入Excel中for (int t = 0, size = vo.getDataList().size(); t < size; t++) {XSSFRow row1 = sheet.createRow(t + 1);SalesListVo salesListVo = vo.getDataList().get(t);Field[] declaredFields = salesListVo.getClass().getDeclaredFields();for (int j = 0; j < declaredFields.length; j++) {cell = row1.createCell(j);Field field = declaredFields[j];field.setAccessible(true);String value = "";try {value = field.get(salesListVo).toString();} catch (IllegalAccessException e) {e.printStackTrace();}cell.setCellValue(value);}}workbookMap.put("清单.xlsx", wk);}return workbookMap;}

3.controller层

        controller层的代码需要注意的是:

1.因为导出Excel一般都是通过浏览器进行下载的,所以入参中需要加入HttpServletResponse

2.调用封装的工具类ExportExcelZip中的downloadExcelForZip方法就可以了

    /*** 导出销货清单(压缩包)*/@GetMapping("/exportSales")public void exportSales(@Valid ExportSalesDto dto, HttpServletResponse response) {log.info("导出清单,入参:{}", dto);Map workbookMap = invoiceReviewService.exportSales(dto);try {ExportExcelZip.downloadExcelForZip(response, workbookMap, "sales.zip");} catch (IOException e) {e.printStackTrace();}}

PS:我这边只是提供了导出zip的demo,里面的表格title、数据等需要根据自己的项目需求替换成自己的代码,切记!!!

最终导出的效果:

 

 

 

 如果这篇文章对您有所帮助,或者有所启发的话,求一键三连:点赞、评论、收藏➕关注,您的支持是我坚持写作最大的动力。

相关内容

热门资讯

华熙生物赵燕谈胶原蛋白乱象:科... 21世纪经济报道记者雷晨 北京报道 近年来,重组胶原蛋白成为医美和护肤领域的热门概念,市场宣传中不乏...
富春染织完成董事会选举换届 开... 7月25日晚间,富春染织公告显示,当日,公司2025年第一次临时股东会和富春染织第四届第一次董事会在...
圣湘生物:两款产品取得医疗器械... 每经AI快讯,圣湘生物(SH 688289,收盘价:22.94元)7月27日晚间发布公告称,圣湘生物...
10年期国债收益率升至1.73... 近期债券市场出现显著调整,多重因素交织推动收益率持续上行。权益市场强势表现与大宗商品价格上涨形成合力...
当对手都在做下沉 蜜雪冰城旗下... [ 今年5月,蜜雪集团跟巴西签署40亿元人民币的采购意向大单,其中大多数是咖啡豆。 ] 当星巴克、瑞...
新手必看!股指期货交易规则基础... 股指期货交易规则,看似复杂抽象,实则与我们的日常生活有着奇妙的共通之处。它就像一场精心编排的生活交响...
王登发履新茅台技开公司“一把手... 一则微信公众号发布的信息,披露了茅台集团旗下的技术开发公司“一把手”已换人。 近日,南都湾财社-酒水...
特斯拉机器人V3量产版亮相!马... 快科技7月27日消息,特斯拉的Optimus人形机器人V3量产版终于要来了!马斯克在最近的财报电话会...
原创 中... 在金融全球化的浪潮中,中国资本市场始终勇立潮头,不断探索前行。7月26日,中国资本市场学会成立大会暨...
报告:我国经济增长保持韧性 下... 央广网北京7月27日消息(记者 樊瑞)近日,中国金融四十人论坛(CF40论坛)发布《2025年第二季...
超6300亿元!A股银行“分红... 7月25日,成都银行完成权益分派股权登记,将于7月28日发放现金红利,这标志着A股上市银行2024年...
老铺黄金:2025年上半年单个... 7月27日晚,老铺黄金(HK06181)披露2025年中期业绩预告。预计2025年上半年实现销售业绩...
保险行业2025年上半年回顾与... 今天分享的是:保险行业2025年上半年回顾与未来展望 报告共计:59页 2025年上半年保险行业回顾...
数币App上新!消费者、商户两... 数字人民币试点持续推进,相关数字钱包手机应用程序功能也在优化中。7月21日,北京商报记者注意到,日前...
A股热点迭出,个股连续涨停!资... 近段时间以来A股市场整体走势较为强劲,上周以来在雅江概念集体上行的推动下涨势更为明显,主要指数不同程...
原创 印... 令人惊讶的是,印度人开始反思自身制造业的发展状况。印度经济学家帕纳加利亚指出,印度原本有机会在20年...
首创证券拟赴港上市,“A+H”... 首创证券在A股上市不足三年便启动赴港上市计划。近日,首创证券公告称,公司董事会已审议通过了公司拟发行...
肥东杨大爷要帮“儿子”还钱,银... “儿子”在外借了2万元还不上 “要债人”电话直接打了过来 还?还是不还? 7月6日 肥东县公安局梁园...
A股上周16家上市公司公布并购... 转自:扬子晚报 扬子晚报网7月27日讯(记者 范晓林 薄云峰)近段时间以来,A股市场并购重组活跃度持...
独家|某股份行改动零售业务关键... 在资产端信贷“投不动”(多家行零售信贷增速连续几个季度放缓、更有甚者个贷投放负增长)、负债端存款“定...