apache POI匯出excel檔案 及單元格合併 、樣式的設定
阿新 • • 發佈:2019-02-13
客戶需要從完單物料資訊中到處excel
大概思路:
單擊某一按鈕,觸發請求至後臺,建立輸出流,匯出excel ^_^
前臺程式碼:
(此段程式碼 註釋部分存在一個問題,註釋部分的請求無效,後臺無法響應前臺請求,
引數傳過去了,後臺也接受了,但輸出流沒有輸出,木雞why)解決方法,用一個重定向代替這個框架sendRequest傳送請求。
isc.IButton.create({ ID:"excelBtn", width:"80", height:"25", icon:"demoApp/page_excel.png", title:"匯出excel", click:function(){ var length = DataList.getSelectedRecords().getLength(); if(length>0){ var projEndId = DataList.getSelectedRecord().projEndId; window.location='com/el/ProjectEnd/createPeSystemReport.action?projEndId=' + projEndId; // RPCManager.sendRequest({ // actionURL:"com/el/ProjectEnd/createPeSystemReport.action", // params:{projEndId:projEndId}, // callback:function() {isc.say("報表匯入成功");} // }); }else{ isc.say("請選擇要導出的專案"); } } }); 後臺程式碼 在web層(controller)寫一個方法,在此方法內獲取資訊資料來源,建立輸出流,然後呼叫生成excel的函式,關閉輸出流。 //----------匯出excel報---------------------------------- @RequestMapping(value = "com/el/ProjectEnd/createPeSystemReport.action") public void exportExecl(HttpServletRequest request, HttpServletResponse response) { int projEndId = Integer.parseInt(request.getParameter("projEndId")); System.out.println("projEndId--:"+projEndId); List<ProjItemSumLine> list = projItemSumLineService.findProjLineByProjEndId(projEndId); ProjItemSumHead projItemSumHead = this.projItemSumHeadService.findProjItemSumHeadByProjEndId(projEndId); response.setContentType("application/vnd.ms-excel"); response.setHeader("Content-Disposition", "attachment; filename=PEMaterialSummary.xls; target=_blank"); String ppc_ = "PPC"; String pmc_ = "PMC"; String purchaser_ = "Purchaser";//採購 String engineer_ = "Engineer"; String ppc = this.projItemSumLiabUserService.findProjItemSumLiabUserName(projEndId, ppc_); String pmc = this.projItemSumLiabUserService.findProjItemSumLiabUserName(projEndId, pmc_); String purchaser = this.projItemSumLiabUserService.findProjItemSumLiabUserName(projEndId, purchaser_); String enginer = this.projItemSumLiabUserService.findProjItemSumLiabUserName(projEndId, engineer_); ExportToExecl ete = new ExportToExecl(); OutputStream os = ete.exportMaterialSummary(list,projItemSumHead,ppc,pmc,purchaser,enginer, response); try { if(os != null){ os.flush(); os.close(); } } catch (IOException e) { e.printStackTrace(); } } } 生成excel的函式: 返回OutputStream型別 package com.el.pe.util.export; import java.io.IOException; import java.io.OutputStream; import java.util.HashMap; import java.util.List; import java.util.Map; import javax.servlet.http.HttpServletResponse; import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermodel.HSSFCellStyle; import org.apache.poi.hssf.usermodel.HSSFFont; import org.apache.poi.hssf.usermodel.HSSFRow; import org.apache.poi.hssf.usermodel.HSSFSheet; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.hssf.util.CellRangeAddress; import org.apache.poi.ss.usermodel.IndexedColors; import com.el.pe.model.ProjItemSumHead; import com.el.pe.model.ProjItemSumLine; public class ExportToExecl { public OutputStream exportMaterialSummary(List<ProjItemSumLine> list, ProjItemSumHead projItemSumHead,String ppc,String pmc,String purchaser,String enginer,HttpServletResponse response) { HSSFWorkbook workbook = new HSSFWorkbook(); HSSFSheet itemSheet = workbook.createSheet("PEMaterialSummary"); int rownum = 2;// 第二行開始 String cellTitle[] = {"列名"}; Map<String, HSSFCellStyle> styles = ExportToExecl.createStyles(workbook); HSSFRow row_first_header = itemSheet.createRow(rownum++); HSSFCell cell_title = null; //建立列名 for (int i = 0; i < cellTitle.length; i++) { itemSheet.setColumnWidth(i, 18 * 256); row_first_header.setHeight((short) (2 * 356)); cell_title = row_first_header.createCell(i); cell_title.setCellType(HSSFCell.CELL_TYPE_STRING); cell_title.setCellStyle(styles.get("cell_header_title")); cell_title.setCellValue(cellTitle[i]); } //合併單元格 四個引數分別為:開始行開始列,結束行結束列 // itemSheet.addMergedRegion(new CellRangeAddress(0,(short)0,1,(short)0)); // itemSheet.addMergedRegion(new CellRangeAddress((short)1, (short)1, (short)2, (short)2)); //寫入資料 HSSFRow row_data = null; HSSFCell cell_data = null; for(int j =0;j<list.size();j++){ for(int i = 0 ;i<cellTitle.length;i++){ //此處省略N個字 } try { OutputStream os = response.getOutputStream(); workbook.write(os); return os; } catch (IOException e) { e.printStackTrace(); } return null; } /*----------建立excel styles----------------------------------*/ private static Map<String, HSSFCellStyle> createStyles(HSSFWorkbook wb) { Map<String, HSSFCellStyle> styles = new HashMap<String, HSSFCellStyle>(); //----------------------標題樣式--------------------------- HSSFCellStyle cell_header_title = wb.createCellStyle(); HSSFFont font_header_title = wb.createFont(); font_header_title.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);// 粗體 font_header_title.setFontHeight((short) (9 * 20)); font_header_title.setFontName("Times New Roman");// 字型樣式 cell_header_title.setFont(font_header_title); cell_header_title.setAlignment(HSSFCellStyle.ALIGN_CENTER);// 居中 cell_header_title.setWrapText(true); styles.put("cell_header_title", cell_header_title); //-----------------------設定字元樣式--------------------------- HSSFCellStyle cell_data_default = wb.createCellStyle(); HSSFFont font_data_default = wb.createFont(); font_data_default.setBoldweight(HSSFFont.BOLDWEIGHT_NORMAL); font_data_default.setFontHeight((short) (8 * 20)); font_data_default.setFontName("Arial Narrow");// 字型樣式 cell_data_default.setFont(font_data_default); cell_data_default.setAlignment(HSSFCellStyle.ALIGN_LEFT);// 居中 cell_data_default.setWrapText(true);// 自動換行 styles.put("cell_data_default", cell_data_default); return styles; } }