色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

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

Springboot POI導出Excel(瀏覽器)

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

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

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

由于本次導出數(shù)據(jù)量較大,這里采用XSSFWorkbook多線程進行導出,注:XSSFWorkbook導出excel文件結(jié)尾為:“.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() + '狀態(tài)'+time; //文件名稱 String excelName = deviceDtls.getName() + '狀態(tài)'+time+'.xlsx'; //文件頭 String[] strings = {'狀態(tài)名稱','開始時間','結(jié)束時間','狀態(tài)時長'}; 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)建一個webbook,對應一個Excel文件 XSSFWorkbook wb = new XSSFWorkbook(); // 第二步,在webbook中添加一個sheet,對應Excel文件中的sheet XSSFSheet sheet = wb.createSheet(sheetName); sheet.setDefaultColumnWidth(20);// 默認列寬 // 第三步,在sheet中添加表頭第0行,注意老版本poi對Excel的行數(shù)列數(shù)有限制short XSSFRow row = sheet.createRow((int) 0); // 第四步,創(chuàng)建單元格,并設置值表頭 設置表頭居中 XSSFCellStyle style = wb.createCellStyle(); // 創(chuàng)建一個居中格式 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; // 第五步,寫入實體數(shù)據(jù) 實際應用中這些數(shù)據(jù)從數(shù)據(jù)庫得到,list中字符串的順序必須和數(shù)組strArray中的順序一致 int startNum ; System.out.println('任務開始,總數(shù):'+list.size()); // 開始時間 long start = System.currentTimeMillis(); System.out.println('線程任務執(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); //設置每一列展示內(nèi)容自己設置 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列表存在順序?qū)年P系 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('線程任務執(zhí)行結(jié)束'); System.err.println('執(zhí)行任務消耗了 :' + (System.currentTimeMillis() - start) + '毫秒'); return filePath; }

//線程同步,保證不會多插入數(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(); // 設置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(瀏覽器)

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

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

標簽: excel
相關文章:
主站蜘蛛池模板: 三级手机在线观看 | 99久久伊人一区二区yy5o99 | 521av香蕉| 亚洲午夜成激人情在线影院 | 男操女免费视频 | 美国一级毛片免费看成人 | 99精品欧美一区二区三区美图 | 国产精品久久毛片 | 亚洲自拍另类 | 欧美成人一级视频 | 揉揉胸摸腿摸下面va视频 | 美国毛片基地a级e片 | 久久久精品久久视频只有精品 | 国产高清一级毛片在线不卡 | 欧美成人久久久 | 日韩a毛片 | 亚洲国产精品二区久久 | 京东一热本色道久久爱 | 日韩一级大片 | 超薄肉色丝袜精品足j福利 超级乱淫视频aⅴ播放视频 | 伊人蜜桃 | 欧美一级片 在线播放 | 992人人tv香蕉国产精品 | 精品视频一区二区三区四区 | 视频一二三区 | 亚洲精品视频专区 | 一级片美女 | 成人三级做爰在线观看男女 | 怡红院免费全部视频在线 | 国产91久久久久久久免费 | 亚洲精品久久九九精品 | 在线亚洲精品国产波多野结衣 | 影音先锋色先锋女同另类 | 国产黄色小视频在线观看 | 国产成人精品亚洲一区 | 毛片亚洲毛片亚洲毛片 | 成人三级在线观看 | 色综合夜夜嗨亚洲一二区 | 国产色视频一区二区三区 | 亚洲第一区精品日韩在线播放 | 成年人免费的视频 |