电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Springboot POI導(dǎo)出Excel(瀏覽器)

瀏覽:127日期:2022-06-17 18:04:30

本文實(shí)例為大家分享了Springboot POI導(dǎo)出Excel的具體代碼,供大家參考,具體內(nèi)容如下

需求:頁(yè)面根據(jù)查詢條件導(dǎo)出(瀏覽器)

由于本次導(dǎo)出數(shù)據(jù)量較大,這里采用XSSFWorkbook多線程進(jìn)行導(dǎo)出,注:XSSFWorkbook導(dǎo)出excel文件結(jié)尾為:“.xlsx”。

導(dǎo)出不需要返回,如有返回則會(huì)報(bào)異常!

//Controller@RequestMapping('/stateExport') public void stateExport(HttpServletResponse response,@RequestParam('deviceId') Long deviceId, String startTime,String endTime) { try { deviceMonitorService.stateExport(response, deviceId, startTime,endTime); LOG.info('導(dǎo)出成功'); } catch (Exception e) { LOG.error('導(dǎo)出異常:',e.getMessage()); } }

//Service @Override public void stateExport(HttpServletResponse response, Long deviceId, String startTime, String endTime) throws Exception{ //list自己查詢得出 List<StateDetailsResult> list = queryStateDetails(deviceId, startTime, endTime); String time = TimeUtils.YEAR_DAY_SECOND_FORMAT.format(new Date()); //sheet名稱 String sheetName = deviceDtls.getName() + '狀態(tài)'+time; //文件名稱 String excelName = deviceDtls.getName() + '狀態(tài)'+time+'.xlsx'; //文件頭 String[] strings = {'狀態(tài)名稱','開(kāi)始時(shí)間','結(jié)束時(shí)間','狀態(tài)時(shí)長(zhǎng)'}; String path = this.getClass().getResource('').getPath() + 'excel'; DownloadFileUtil.createDirs(path); String filePath = path + '/' + sheetName + '.xls'; stateCreateExcel(list,strings,sheetName,excelName,filePath); DownloadFileUtil.download(filePath, response); }

public String stateCreateExcel(List<StateDetailsResult> list, String[] strArray,String sheetName,String excelName,String filePath)throws Exception { // 總數(shù)據(jù)條數(shù) int dataSize = list.size(); // 線程數(shù) int threadNum = 2; int threadSize = dataSize / threadNum; ExecutorService exec = Executors.newFixedThreadPool(threadNum); //cutList 和輸入list類型保持一致 List<StateDetailsResult> cutList = null; // 第一步,創(chuàng)建一個(gè)webbook,對(duì)應(yīng)一個(gè)Excel文件 XSSFWorkbook wb = new XSSFWorkbook(); // 第二步,在webbook中添加一個(gè)sheet,對(duì)應(yīng)Excel文件中的sheet XSSFSheet sheet = wb.createSheet(sheetName); sheet.setDefaultColumnWidth(20);// 默認(rèn)列寬 // 第三步,在sheet中添加表頭第0行,注意老版本poi對(duì)Excel的行數(shù)列數(shù)有限制short XSSFRow row = sheet.createRow((int) 0); // 第四步,創(chuàng)建單元格,并設(shè)置值表頭 設(shè)置表頭居中 XSSFCellStyle style = wb.createCellStyle(); // 創(chuàng)建一個(gè)居中格式 style.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 添加excel title XSSFCell cell = null; for (int i = 0; i < strArray.length; i++) { cell = row.createCell((short) i); cell.setCellValue(strArray[i]); cell.setCellStyle(style); } List<Callable<Integer>> tasks = new ArrayList<Callable<Integer>>(); Callable<Integer> task = null; // 第五步,寫(xiě)入實(shí)體數(shù)據(jù) 實(shí)際應(yīng)用中這些數(shù)據(jù)從數(shù)據(jù)庫(kù)得到,list中字符串的順序必須和數(shù)組strArray中的順序一致 int startNum ; System.out.println('任務(wù)開(kāi)始,總數(shù):'+list.size()); // 開(kāi)始時(shí)間 long start = System.currentTimeMillis(); System.out.println('線程任務(wù)執(zhí)行'); for (int i = 0; i < threadNum; i++) { startNum = threadSize * i; if (i == threadNum - 1) {cutList = list.subList(threadSize * i, dataSize); } else {cutList = list.subList(threadSize * i, threadSize * (i + 1)); } //listStr 和輸入list類型保持一致 final List<StateDetailsResult> listStr = cutList; int finalStartNum = startNum; task = new Callable<Integer>() {final int s= finalStartNum;@Overridepublic Integer call() throws Exception { for(int j=0;j<listStr.size();j++){ XSSFRow row =getRow(sheet,s+j); //設(shè)置每一列展示內(nèi)容自己設(shè)置 row.createCell(0).setCellValue(listStr.get(j).getName()); row.createCell(1).setCellValue(listStr.get(j).getStartDateTime()); row.createCell(2).setCellValue(listStr.get(j).getEndDateTime()); row.createCell(3).setCellValue(listStr.get(j).getDateTime()); } return 1;} }; // 這里提交的任務(wù)容器列表和返回的Future列表存在順序?qū)?yīng)的關(guān)系 tasks.add(task); } try { List<Future<Integer>> results = exec.invokeAll(tasks); } catch (Exception e) { e.printStackTrace(); } // 關(guān)閉線程池 exec.shutdown(); DownloadFileUtil.delfile(filePath); // 第六步,將文件存到指定位置 try { FileOutputStream fout = new FileOutputStream(filePath); wb.write(fout); fout.flush(); fout.close(); } catch (Exception e) { e.printStackTrace(); } System.out.println('線程任務(wù)執(zhí)行結(jié)束'); System.err.println('執(zhí)行任務(wù)消耗了 :' + (System.currentTimeMillis() - start) + '毫秒'); return filePath; }

//線程同步,保證不會(huì)多插入數(shù)據(jù)private synchronized XSSFRow getRow(XSSFSheet sheet, int rownum) { //如果不包含列頭,+1去掉即可 return sheet.createRow(rownum+1); }

最后附上使用的工具類

package com.sec.deviceband.utils;import javax.servlet.http.HttpServletResponse;import java.io.*;import java.net.URLEncoder;public class DownloadFileUtil { /** * 判斷路徑是否存在不存在則創(chuàng)建 * @param path */ public static void createDirs(String path) { File file = new File(path); if (!file.exists()) { file.mkdirs(); } } /** * 下載 * * @param path * @param response */ public static void download(String path, HttpServletResponse response) { try { // path是指欲下載的文件的路徑。 File file = new File(path); // 取得文件名。 String filename = file.getName(); // 以流的形式下載文件。 InputStream fis = new BufferedInputStream(new FileInputStream(path)); byte[] buffer = new byte[fis.available()]; fis.read(buffer); fis.close(); // 清空response response.reset(); // 設(shè)置response的Header response.addHeader('Content-Disposition', 'attachment;filename=' + URLEncoder.encode(filename, 'utf-8')); response.addHeader('Content-Length', '' + file.length()); OutputStream toClient = new BufferedOutputStream( response.getOutputStream()); response.setContentType('application/vnd.ms-excel;charset=utf-8'); toClient.write(buffer); toClient.flush(); toClient.close(); delfile(path); } catch (IOException ex) { ex.printStackTrace(); } } /** * 判斷文件是否存在則刪除 * * @param filepath */ public static void delfile(String filepath) { File file = new File(filepath); if (file.exists()) { file.delete(); } }}

測(cè)試方式:瀏覽器輸入請(qǐng)求路徑

Springboot POI導(dǎo)出Excel(瀏覽器)

測(cè)試效果:

Springboot POI導(dǎo)出Excel(瀏覽器)

Springboot POI導(dǎo)出Excel(瀏覽器)

由于水平有限,博客中難免會(huì)有一些錯(cuò)誤,有紕漏之處懇請(qǐng)各位大佬不吝賜教!

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: excel
相關(guān)文章:
主站蜘蛛池模板: 天津电机维修|水泵维修-天津晟佳机电设备有限公司 | 济南ISO9000认证咨询代理公司,ISO9001认证,CMA实验室认证,ISO/TS16949认证,服务体系认证,资产管理体系认证,SC食品生产许可证- 济南创远企业管理咨询有限公司 郑州电线电缆厂家-防火|低压|低烟无卤电缆-河南明星电缆 | 动库网动库商城-体育用品专卖店:羽毛球,乒乓球拍,网球,户外装备,运动鞋,运动包,运动服饰专卖店-正品运动品网上商城动库商城网 - 动库商城 | 金属抛光机-磁悬浮抛光机-磁力研磨机-磁力清洗机 - 苏州冠古科技 | 东莞动力锂电池保护板_BMS智能软件保护板_锂电池主动均衡保护板-东莞市倡芯电子科技有限公司 | 丙烷/液氧/液氮气化器,丙烷/液氧/液氮汽化器-无锡舍勒能源科技有限公司 | PU树脂_水性聚氨酯树脂_聚氨酯固化剂_聚氨酯树脂厂家_宝景化工 | Type-c防水母座|贴片母座|耳机接口|Type-c插座-深圳市步步精科技有限公司 | 大通天成企业资质代办_承装修试电力设施许可证_增值电信业务经营许可证_无人机运营合格证_广播电视节目制作许可证 | 天津热油泵_管道泵_天津高温热油泵-天津市金丰泰机械泵业有限公司【官方网站】 | 北京办公室装修,办公室设计,写字楼装修-北京金视觉装饰工程公司 北京成考网-北京成人高考网 | 会议会展活动拍摄_年会庆典演出跟拍_摄影摄像直播-艾木传媒 | 空气能采暖,热泵烘干机,空气源热水机组|设备|厂家,东莞高温热泵_正旭新能源 | 变色龙云 - 打包app_原生app_在线制作平台_短链接_ip查询 | 水平筛厂家-三轴椭圆水平振动筛-泥沙震动筛设备_山东奥凯诺矿机 包装设计公司,产品包装设计|包装制作,包装盒定制厂家-汇包装【官方网站】 | 泰国试管婴儿_泰国第三代试管婴儿费用|成功率|医院—新生代海外医疗 | 青岛空压机,青岛空压机维修/保养,青岛空压机销售/出租公司,青岛空压机厂家电话 | 废水处理-废气处理-工业废水处理-工业废气处理工程-深圳丰绿环保废气处理公司 | 济南轻型钢结构/济南铁艺护栏/济南铁艺大门-济南燕翔铁艺制品有限公司 | 北京模型公司-军事模型-工业模型制作-北京百艺模型沙盘公司 | 泰国试管婴儿_泰国第三代试管婴儿费用|成功率|医院—新生代海外医疗 | 上海皓越真空设备有限公司官网-真空炉-真空热压烧结炉-sps放电等离子烧结炉 | 艺术生文化课培训|艺术生文化课辅导冲刺-济南启迪学校 | 玉米深加工设备-玉米深加工机械-新型玉米工机械生产厂家-河南粮院机械制造有限公司 | 硬齿面减速机[型号全],ZQ减速机-淄博久增机械 | 浇钢砖,流钢砖_厂家价低-淄博恒森耐火材料有限公司 | 威海防火彩钢板,威海岩棉复合板,威海彩钢瓦-文登区九龙岩棉复合板厂 | 南京技嘉环保科技有限公司-杀菌除臭剂|污水|垃圾|厕所|橡胶厂|化工厂|铸造厂除臭剂 | 压片机_高速_单冲_双层_花篮式_多功能旋转压片机-上海天九压片机厂家 | 无痕胶_可移胶_无痕双面胶带_可移无痕胶厂家-东莞凯峰 | 福州仿石漆加盟_福建仿石漆厂家-外墙仿石漆加盟推荐铁壁金钢(福建)新材料科技有限公司有保障 | 安徽净化工程设计_无尘净化车间工程_合肥净化实验室_安徽创世环境科技有限公司 | 新密高铝耐火砖,轻质保温砖价格,浇注料厂家直销-郑州荣盛窑炉耐火材料有限公司 | 道达尔润滑油-食品级润滑油-道达尔导热油-合成导热油,深圳道达尔代理商合-深圳浩方正大官网 | 聚合氯化铝价格_聚合氯化铝厂家_pac絮凝剂-唐达净水官网 | TPE_TPE热塑性弹性体_TPE原料价格_TPE材料厂家-惠州市中塑王塑胶制品公司- 中塑王塑胶制品有限公司 | 儋州在线-儋州招聘找工作、找房子、找对象,儋州综合生活信息门户! | 珠海冷却塔降噪维修_冷却塔改造报价_凉水塔风机维修厂家- 广东康明节能空调有限公司 | 档案密集架,移动密集架,手摇式密集架,吉林档案密集架-厂家直销★价格公道★质量保证 | UV固化机_UVLED光固化机_UV干燥机生产厂家-上海冠顶公司专业生产UV固化机设备 | IHDW_TOSOKU_NEMICON_EHDW系列电子手轮,HC1系列电子手轮-上海莆林电子设备有限公司 |