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、数据等需要根据自己的项目需求替换成自己的代码,切记!!!

最终导出的效果:

 

 

 

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

相关内容

热门资讯

企业IP打造指南:小公司低成本... 小公司做企业IP,不是为了装门面,而是让客户在没见到你之前,就能通过内容知道你是谁、你解决什么问题、...
官方:赵心童入选世界斯诺克名人... 北京时间5月8日消息,世界斯诺克巡回赛(WST)今日正式公布了2025/26赛季年终奖项及名人堂更新...
小灰熊AI学员王锋:希望能跟上... 35了,老程序员了。 从进入互联网行业到现在,其实已经做了很多年移动端开发。最早那几年,安卓行业发展...
原创 2... 2026年全国两会把稳定房地产市场列为重点工作,政府工作报告明确提出因城施策控增量、去库存、优供给。...
一年翻倍,六年未归——徽商银行... 文:向善财经 今年的港股市场,与A股市场出现了明显的分化。 A股这边,科技板块在AI浪潮中热闹非凡;...
古井贡酒2025:在行业深度调... 以“稳”为底、以“新”为翼。 文/每日财报 杜康 在行业库存高企、价格倒挂的背景下,当多数酒企在为...
好上好8408万收购鼎瑞芯加码... 5月7日晚,好上好(001298.SZ)抛出一份收购公告,拟以8408万元现金收购深圳市鼎瑞芯科技有...
全面大撤离!李嘉诚英国“套现”... 突发,李嘉诚又卖了。 这次,套现了455亿。 金额不少,但更值得关注的是透露着不同寻常的信号。 因为...
油气价格上涨加剧法国一季度贸易... 据新华社,法国海关7日发布的数据显示,受中东局势推高国际油气价格影响,法国今年第一季度贸易逆差扩大至...
昆仑芯启动科创板IPO上市辅导... 5月8日,据证监会官网显示,昆仑芯(北京)科技股份有限公司于2026年5月7日正式启动科创板上市辅导...
贵州茅台酒股份有限公司关于回购... 来源:上海证券报 证券代码:600519 证券简称:贵州茅台 公告编号:临2026-016 贵州茅...
百度昆仑芯启动科创板上市辅导,... 5月8日,证监会官网显示,昆仑芯(北京)科技股份有限公司 (下称“昆仑芯”)于2026年5月7日正式...
滕州信华的承压时刻:罚单、失信... 2026年4月末,滕州信华美元债单日跌近2%,关联方被列“老赖”。半年前,这家AA+城投曾因非市场化...
002808,或被终止上市! 【导读】因触及财务类退市指标,*ST恒久或被终止上市 中国基金报记者 李智 又一A股或被终止上市。 ...
院士团队掌舵,溧阳这家企业已完... 近日,溧阳天目先导电池材料科技有限公司(下称“天目先导”)官宣完成B轮融资,投资方包括知卓创新资本、...
工商银行全新推出“工盈研选”品... 深圳商报·读创客户端记者 詹钰叶 近日,工商银行重磅推出「工盈研选」基金销售服务品牌,以客户盈利为核...
和讯信息胡云龙:逼空走势,周五... 今天市场出现逼空走势,场内投资者因持有筹码而尤为受益。五一前布局的投资者当前收获颇丰。然而,随着上证...
今晚,油价上调! 4月21日国内成品油价格下调以来,国际市场原油价格剧烈震荡,前期大幅上涨后近日有所回落,本次调价的前...
南方东英旗下两倍做多海力士,成... 【导读】南方东英旗下两倍做多海力士,成为全球最大的个股杠杆及反向产品 中国基金报记者 伊万 人工智能...
原创 金... 黄金,这东西从古至今就没离开过中国人的生活。从老辈人压箱底的小黄鱼,到如今年轻人结婚绕不开的“三金”...