日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

Springboot POI導出Excel(瀏覽器)

瀏覽:175日期: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
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久国产成人| 欧美成人综合| 一区二区日韩免费看| 国产综合亚洲精品一区二| 特黄毛片在线观看| 久久久久久色| 日本中文字幕不卡| 日韩国产一区二| 婷婷视频一区二区三区| 亚洲人妖在线| 欧美另类中文字幕 | 欧美日韩一二| 久久九九99| 9久re热视频在线精品| 亚洲人成高清| 久久99久久人婷婷精品综合| 国产一区二区三区四区五区传媒| 亚洲精品成人图区| 99精品美女| 欧美一区激情| 日本亚洲三级在线| 日本韩国欧美超级黄在线观看| 亚洲综合婷婷| 成人av三级| 蜜臀av在线播放一区二区三区| 美女久久久久久 | 丁香六月综合| 亚洲精品无播放器在线播放| 久久中文欧美| 性欧美xxxx免费岛国不卡电影| 日韩天堂av| 日本免费在线视频不卡一不卡二| 国产精品xxx在线观看| zzzwww在线看片免费| 91成人超碰| 日韩欧美另类中文字幕| 国产日韩欧美| 日产精品一区二区| 欧美日韩三区| 国产欧美日韩精品一区二区免费| 日韩中文在线电影| 亚洲伊人精品酒店| 开心激情综合| 亚洲激情偷拍| 国产精品久久久久久久久久久久久久久 | 亚洲精品少妇| 精品一区二区三区中文字幕在线| 成人精品亚洲| 日本中文字幕不卡| 桃色一区二区| 日本在线一区二区三区| 成人国产综合| 免费成人av在线播放| 精品国产a一区二区三区v免费| 欧美精品一区二区三区精品| 欧美一区在线观看视频| 中文字幕在线免费观看视频| 男人的天堂亚洲一区| 水蜜桃久久夜色精品一区| 蜜桃视频一区二区三区在线观看| 国产成人精品福利| 亚洲精品一级二级三级| 91一区二区| 日本va欧美va瓶| 久久精品国产亚洲夜色av网站| 欧美日韩中出| 亚洲精品一二三区区别| 九九九精品视频| 日本中文字幕不卡| 欧美粗暴jizz性欧美20| 久久精品午夜| 中文字幕av一区二区三区人| 正在播放日韩精品| 国产亚洲一卡2卡3卡4卡新区| 黄色亚洲免费| 国产中文欧美日韩在线| 日韩激情一区二区| 国产女优一区| 久久人人97超碰国产公开结果| 久久成人福利| 日韩欧美久久| 亚洲永久字幕| 久久天堂av| 欧美aaaaaa午夜精品| 亚洲美女91| 樱桃成人精品视频在线播放| 精品一区二区三区中文字幕视频| 亚洲一区二区av| 欧美日韩国产在线观看网站| 在线中文字幕播放| 麻豆国产欧美一区二区三区 | 深夜福利一区| 偷拍欧美精品| 精品日韩视频| 精品欧美日韩精品| 欧美日韩一区自拍| 蜜臀久久久久久久| 欧美日韩中文一区二区| 国产中文字幕一区二区三区| 日本免费一区二区视频| 国产一区导航| 亚洲精品一二三区区别| 日韩高清中文字幕一区二区| www.51av欧美视频| 久久精品国产福利| 国产精品99久久免费观看| 日韩国产在线观看| 亚洲影院天堂中文av色| 久久福利一区| 国产视频一区三区| 国产尤物精品| 99久久久久国产精品| 日韩在线二区| 日韩一区亚洲二区| 日本一二区不卡| 精品国产美女a久久9999| 久久精品伊人| 国产一区二区三区不卡av| 精品三级国产| 国产一区二区三区四区二区| 国产成人精品三级高清久久91| 精品国产午夜| 97精品中文字幕| 日韩电影免费网址| 日韩在线免费| 国产一在线精品一区在线观看| 久久精品亚洲人成影院 | 婷婷亚洲成人| 日韩国产91| 国产精品中文字幕亚洲欧美 | 99精品视频在线| 99成人在线视频| 五月天久久网站| 国产精品嫩草99av在线| 久久午夜视频| 日韩av网站在线观看| 国产日韩欧美在线播放不卡| 国产欧美日韩视频在线| 久久精品国产网站| 国精品产品一区| 欧美aa一级| 欧美福利在线| 日韩精品一二三四| 欧美亚洲人成在线| 精品美女视频 | 午夜久久中文| 在线国产一区二区| 视频一区国产视频| 日本va欧美va欧美va精品| 久久99精品久久久久久园产越南 | 日韩精品一卡| 黑丝一区二区| 亚洲免费资源| 国产劲爆久久| 欧美一区久久久| 影院欧美亚洲| 日本va欧美va精品发布| 国产一区二区三区国产精品| 久久久久99| 男人天堂欧美日韩| 国产美女撒尿一区二区| 中文字幕在线高清| 日韩中文字幕亚洲一区二区va在线| 日韩1区2区3区| 国产精品久久观看| 在线亚洲激情| 91亚洲精品视频在线观看| 色婷婷综合网| 久久亚洲视频| 久久只有精品| 国内激情久久| 国产日韩免费| 久久精品导航| 日韩精品a在线观看91| av资源中文在线天堂| 视频一区视频二区中文字幕| 精品亚洲二区| 久久亚洲风情| 国产成人免费| 免费不卡在线观看| 98精品久久久久久久| 亚洲欧美日韩专区| 欧美国产另类| 午夜在线一区二区| 精品国产精品国产偷麻豆| 在线精品小视频| 久久不卡国产精品一区二区| 黄色欧美日韩| 国产成人精品一区二区三区在线| 老鸭窝毛片一区二区三区| 国内精品伊人| 久久高清免费观看| 日韩精品永久网址| 91精品麻豆| 女人天堂亚洲aⅴ在线观看| 国产精品白丝久久av网站| 91成人精品视频| 精品高清久久| 日韩精品久久理论片| 蜜桃成人av|