<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
//匯出檔案介面 public String export(){ return this.myExport(exportList); }
private String myExport(List<BusinessDept> list){ com.bronzesoft.power.tools.json.JSONObject info = new com.bronzesoft.power.tools.json.JSONObject(); try{ List<String> headList = new ArrayList<String>(Arrays.asList("年", "月", "部門","部門負責人","經營值","收入", "支出","填報工時","標準工時","經營引數")); Commonutil.export(list,headList,"部門經營總覽匯出"); info = Commonutil.setInfo(info,"部門經營總覽匯出"); }catch (Exception e){ LogUtil.error(this.getClass().getName()+".exportExcel()", e); } return info.toString(); }
首先,理解一下一個Excel的檔案的組織形式,一個Excel檔案對應於一個workbook(XSSFWorkbook),一個workbook可以有多個sheet(XSSFSheet)組成,一個sheet是由多個row(XSSFRow)組成,一個row是由多個cell(XSSFCell)組成。
public static <T> boolean export(List<T> list,List<String> headList,String fileName){ return myExport(list,headList,fileName,com.bronzesoft.rdm.platform.util.Constants.PATH + com.bronzesoft.power.platform.Constants.TEMPFOLDER_DIR ); } //將list匯出為excel,檔名為fileName public static <T> boolean myExport(List<T> list,List<String> headList,String fileName,String path){ try{ if(!checkListAndHead(list,headList)){ LogUtil.info( "head的長度有問題,匯出的檔案不正確" ); } File file = new File(path + File.separator + fileName + ".xlsx"); if(!file.exists()) { file.createNewFile(); } //建立對應excel檔案,儲存路徑path待確定 XSSFWorkbook workBook = new XSSFWorkbook(); //建立一個excel的sheet頁 XSSFSheet sheet = workBook.createSheet(fileName); XSSFRow row = null; XSSFCell cell = null; Map<String, CellStyle> styles = StyleUtil.createStyles(workBook); //表頭樣式 CellStyle headCenterIndex = styles.get("headCenter"); //列的樣式居中,背景顏色為白色 CellStyle center = styles.get("centerWhite"); row = sheet.createRow(0); //表頭資料 for (int i = 0; i < headList.size(); i++) { //建立列 cell = row.createCell(i); //設定列的value cell.setCellValue(headList.get(i)); //設定列的樣式 cell.setCellStyle(headCenterIndex); } //表格資料 //寫入表格資料 String codeName = ""; int rownum = 1; T obj = null; for(int i = 0; i < list.size(); i++){ obj = list.get(i); if(null != obj){ Field[] fields = obj.getClass().getDeclaredFields(); row = sheet.createRow(rownum); for(int j = 0; j< fields.length; j++){ fields[j].setAccessible(true); codeName = String.valueOf(fields[j].get(obj)); //建立第j列 cell = row.createCell(j); cell.setCellValue(Commonutil.getStringVal(codeName)); cell.setCellStyle(center); } } rownum++; } // //i代表列,設定列的寬度 // for (int i = 0; i < headList.size(); i++) { // if(i == 0){ // sheet.setColumnWidth(i, 2000); // }else if(i == 1 || i == 3){ // sheet.setColumnWidth(i, 6000); // }else{ // sheet.setColumnWidth(i, 4000); // } // } //將檔案寫到臨時目錄 FileOutputStream out = new FileOutputStream(file); workBook.write(out); }catch (Exception e){ LogUtil.error(fileName + "export失敗" ); } return true; } //檢查head的size是否符合規範 public static <T> boolean checkListAndHead(List<T> list,List<String> headList){ if(list.size()>0){ T t = list.get(0); if(getColumnCount(t) != headList.size()){ LogUtil.info( "head的長度有問題" ); return false; } } return true; } //獲取一個物件成員變數的個數 public static <T> int getColumnCount(T t){ Field[] fields = t.getClass().getDeclaredFields(); int count = fields.length; return count; }
public static JSONObject setInfo(JSONObject info,String fileName) throws Exception { Storage s = Commonutil.getDefaultStorage(); info.put("port", String.valueOf(s.getPort())); info.put("dirAddress", Base64Util.encode(com.bronzesoft.rdm.platform.util.Constants.PATH)); info.put("address", Base64Util.encode(com.bronzesoft.power.platform.Constants.TEMPFOLDER_DIR + File.separator + fileName + ".xlsx")); info.put("name", Base64Util.encode(fileName)); info.put("extendName", "xlsx"); return info; }
function doExport(){ synAjax.tabCall("com.bronzesoft.rdm.SeDeptTotalTab", "export", null, function(data){ doDownload(data); }); } function doDownload(data){ console.log('data',data) r = eval('('+data+')'); $("#_file_dir").val(r.dirAddress); $("#_file_address").val(r.address); $("#_file_name").val(r.name); $("#_file_extname").val(r.extendName); if ($.browser.safari) { $("#_file_downform").attr("target", ""); } var servlet = powerPath + "download"; $("#_file_downform").attr("action", servlet).submit(); }
到此這篇關於java中的export方法實現匯出excel檔案的文章就介紹到這了,更多相關java匯出excel檔案內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45