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

您的位置:首頁技術文章
文章詳情頁

Springboot POI導出Excel(瀏覽器)

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

本文實例為大家分享了Springboot POI導出Excel的具體代碼,供大家參考,具體內容如下

需求:頁面根據查詢條件導出(瀏覽器)

由于本次導出數據量較大,這里采用XSSFWorkbook多線程進行導出,注:XSSFWorkbook導出excel文件結尾為:“.xlsx”。

導出不需要返回,如有返回則會報異常!

//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('導出成功'); } catch (Exception e) { LOG.error('導出異常:',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() + '狀態'+time; //文件名稱 String excelName = deviceDtls.getName() + '狀態'+time+'.xlsx'; //文件頭 String[] strings = {'狀態名稱','開始時間','結束時間','狀態時長'}; 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 { // 總數據條數 int dataSize = list.size(); // 線程數 int threadNum = 2; int threadSize = dataSize / threadNum; ExecutorService exec = Executors.newFixedThreadPool(threadNum); //cutList 和輸入list類型保持一致 List<StateDetailsResult> cutList = null; // 第一步,創建一個webbook,對應一個Excel文件 XSSFWorkbook wb = new XSSFWorkbook(); // 第二步,在webbook中添加一個sheet,對應Excel文件中的sheet XSSFSheet sheet = wb.createSheet(sheetName); sheet.setDefaultColumnWidth(20);// 默認列寬 // 第三步,在sheet中添加表頭第0行,注意老版本poi對Excel的行數列數有限制short XSSFRow row = sheet.createRow((int) 0); // 第四步,創建單元格,并設置值表頭 設置表頭居中 XSSFCellStyle style = wb.createCellStyle(); // 創建一個居中格式 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; // 第五步,寫入實體數據 實際應用中這些數據從數據庫得到,list中字符串的順序必須和數組strArray中的順序一致 int startNum ; System.out.println('任務開始,總數:'+list.size()); // 開始時間 long start = System.currentTimeMillis(); System.out.println('線程任務執行'); 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); //設置每一列展示內容自己設置 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;} }; // 這里提交的任務容器列表和返回的Future列表存在順序對應的關系 tasks.add(task); } try { List<Future<Integer>> results = exec.invokeAll(tasks); } catch (Exception e) { e.printStackTrace(); } // 關閉線程池 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('線程任務執行結束'); System.err.println('執行任務消耗了 :' + (System.currentTimeMillis() - start) + '毫秒'); return filePath; }

//線程同步,保證不會多插入數據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 { /** * 判斷路徑是否存在不存在則創建 * @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(); // 設置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(); } }}

測試方式:瀏覽器輸入請求路徑

Springboot POI導出Excel(瀏覽器)

測試效果:

Springboot POI導出Excel(瀏覽器)

Springboot POI導出Excel(瀏覽器)

由于水平有限,博客中難免會有一些錯誤,有紕漏之處懇請各位大佬不吝賜教!

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: excel
相關文章:
主站蜘蛛池模板: 不锈钢螺丝 - 六角螺丝厂家 - 不锈钢紧固件 - 万千紧固件--紧固件一站式采购 | 工作心得_读书心得_学习心得_找心得体会范文就上学道文库 | 万烁建筑设计院-建筑设计公司加盟,设计院加盟分公司,市政设计加盟 | 除甲醛公司-甲醛检测-广西雅居环境科技有限公司 | 企业管理培训,企业培训公开课,企业内训课程,企业培训师 - 名课堂企业管理培训网 | 北京亦庄厂房出租_经开区产业园招商信息平台 | 粘度计,数显粘度计,指针旋转粘度计| 掺铥光纤放大器-C/L波段光纤放大器-小信号光纤放大器-合肥脉锐光电技术有限公司 | 工业胀紧套_万向节联轴器_链条-规格齐全-型号选购-非标订做-厂家批发价格-上海乙谛精密机械有限公司 | 云南丰泰挖掘机修理厂-挖掘机维修,翻新,再制造的大型企业-云南丰泰工程机械维修有限公司 | 高精度-恒温冷水机-螺杆式冰水机-蒸发冷冷水机-北京蓝海神骏科技有限公司 | 岩棉板|岩棉复合板|聚氨酯夹芯板|岩棉夹芯板|彩钢夹芯板-江苏恒海钢结构 | 龙门加工中心-数控龙门加工中心厂家价格-山东海特数控机床有限公司_龙门加工中心-数控龙门加工中心厂家价格-山东海特数控机床有限公司 | 对夹式止回阀_对夹式蝶形止回阀_对夹式软密封止回阀_超薄型止回阀_不锈钢底阀-温州上炬阀门科技有限公司 | 粉末冶金-粉末冶金齿轮-粉末冶金零件厂家-东莞市正朗精密金属零件有限公司 | 电机修理_二手电机专家-河北豫通机电设备有限公司(原石家庄冀华高压电机维修中心) | 精密交叉滚子轴承厂家,转盘轴承,YRT转台轴承-洛阳千协轴承 | 北京环球北美考试院【官方网站】|北京托福培训班|北京托福培训 | 数控专用机床,专用机床,自动线,组合机床,动力头,自动化加工生产线,江苏海鑫机床有限公司 | 工控机-工业平板电脑-研华工控机-研越无风扇嵌入式box工控机 | 留学生辅导网-在线课程论文辅导-留学生挂科申诉机构 | 船老大板材_浙江船老大全屋定制_船老大官网| elisa试剂盒-PCR试剂盒「上海谷研实业有限公司」 | 中视电广_短视频拍摄_短视频推广_短视频代运营_宣传片拍摄_影视广告制作_中视电广 | 14米地磅厂家价价格,150吨地磅厂家价格-百科 | 北京模型公司-军事模型-工业模型制作-北京百艺模型沙盘公司 | 沟盖板_复合沟盖板厂_电力盖板_树脂雨水篦子-淄博拜斯特 | 连续油炸机,全自动油炸机,花生米油炸机-烟台茂源食品机械制造有限公司 | 玻璃钢型材-玻璃钢风管-玻璃钢管道,生产厂家-[江苏欧升玻璃钢制造有限公司] | 动物解剖台-成蚊接触筒-标本工具箱-负压实验台-北京哲成科技有限公司 | 石家庄装修设计_室内家装设计_别墅装饰装修公司-石家庄金舍装饰官网 | 电气控制系统集成商-PLC控制柜变频控制柜-非标自动化定制-电气控制柜成套-NIDEC CT变频器-威肯自动化控制 | 杭州厂房降温,车间降温设备,车间通风降温,厂房降温方案,杭州嘉友实业爽风品牌 | 实木家具_实木家具定制_全屋定制_美式家具_圣蒂斯堡官网 | BHK汞灯-百科|上海熙浩实业有限公司| CNC机加工-数控加工-精密零件加工-ISO认证厂家-鑫创盟 | 影视模板素材_原创专业影视实拍视频素材-8k像素素材网 | 机器视觉检测系统-视觉检测系统-机器视觉系统-ccd检测系统-视觉控制器-视控一体机 -海克易邦 | 变色龙云 - 打包app_原生app_在线制作平台_短链接_ip查询 | IWIS链条代理-ALPS耦合透镜-硅烷预处理剂-上海顶楚电子有限公司 lcd条形屏-液晶长条屏-户外广告屏-条形智能显示屏-深圳市条形智能电子有限公司 | CE认证_FCC认证_CCC认证_MFI认证_UN38.3认证-微测检测 CNAS实验室 |