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

最终导出的效果:

 

 

 

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

相关内容

热门资讯

山西太钢不锈钢股份有限公司 2... 来源:证券日报 证券代码:000825 证券简称:太钢不锈 公告编号:2026-001 本公司及董...
把自己的银行贷款出借给别人,有... 新京报讯(记者张静姝 通讯员邸越洋)因贷款出借后未被归还,原告牛女士将被告杨甲、杨乙诉至法院,要求二...
金价暴跌,刚买的金饰能退吗?有... 黄金价格大跌,多品牌设置退货手续费。 在过去两三天,现货黄金价格经历了“过山车”般的行情,受金价下跌...
预计赚超2500万!“豆腐大王... 图片来源:图虫创意 在经历了一年亏损后,“豆腐大王”祖名股份(003030.SZ)成功实现扭亏为盈。...
特朗普提名“自己人”沃什执掌美... 据新华社报道,当地时间1月30日,美国总统特朗普通过社交媒体宣布,提名美国联邦储备委员会前理事凯文·...
爱芯元智将上市:连年大额亏损,... 撰稿|多客 来源|贝多商业&贝多财经 1月30日,爱芯元智半导体股份有限公司(下称“爱芯元智”,HK...
一夜之间,10只A股拉响警报:... 【导读】深康佳A等10家公司昨夜拉响退市警报 中国基金报记者 夏天 1月30日晚间,A股市场迎来一波...
谁在操控淳厚基金?左季庆为谁趟... 2026年1月6日,证监会一纸批复核准上海长宁国有资产经营投资有限公司(下称“长宁国资”)成为淳厚基...
工商银行党委副书记、行长刘珺会... 人民财讯1月31日电,1月29日,工商银行党委副书记、行长刘珺会见来访的上海电气集团党委书记、董事长...
布米普特拉北京投资基金管理有限... 从亚马逊到联合包裹,一场席卷美国企业的“瘦身”行动正在持续。多家企业近期承认,近年来的扩张步伐迈得过...
酒价内参1月31日价格发布 飞... 来源:酒业内参 新浪财经“酒价内参”过去24小时收集的数据显示,中国白酒市场十大单品的终端零售均价在...
筹码集中的绩优滞涨热门赛道股出... 2025年以来,在受多重因素的刺激下,科技、航天、基础化工等热门赛道中走出轮番上涨的结构性行情,其中...
2026年A股上市公司退市潮开... 来源:界面新闻 界面新闻记者 赵阳戈 随着2026年序幕拉开,A股市场新一轮“出清”即将上演。...
雷军官宣新直播:走进小米汽车工... 【太平洋科技快讯】1 月 31 日消息,小米创办人、董事长兼 CEO 雷军在社交媒体发文宣布,将于 ...
现货黄金直线跳水,跌破5200... 新闻荐读 1月29日晚,现货黄金白银快速走低,回吐盘中全部涨幅。23:15左右,现货黄金跌破5300...
加拿大拟与多国联合设立国防银行 新华社北京1月31日电 加拿大财政部长商鹏飞1月30日说,加拿大将在未来数月与国际伙伴密切合作,推进...
马斯克大消息!SpaceX申请... 据券商中国,美东时间1月30日,路透社报道,据两位知情人士透露,马斯克旗下SpaceX公司2025年...
澳网:雷巴金娜2-1萨巴伦卡女... 北京时间1月31日,2026赛季网球大满贯澳大利亚公开赛继续进行,在女单决赛中,5号种子雷巴金娜6-...
春节前白酒促销热:“扫码抽黄金... 春节临近,白酒市场再现价格异动。 近日,飞天茅台批价拉升,有酒商直言“年前要冲2000元关口”,引发...