国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JSP > 正文

jsp導出excel并支持分sheet導出的方法

2024-09-05 00:22:22
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了jsp導出excel并支持分sheet導出的方法,涉及Java針對excel操作的相關技巧,具有一定參考借鑒價值,需要的朋友可以參考下

本文實例講述了jsp導出excel并支持分sheet導出的方法。分享給大家供大家參考,具體如下:

 

 
  1. public DownloadFile exportToExcel() throws Exception{ 
  2. String config_value = systemConfigService.getConfigValueByKey("Export.Xls"); 
  3. logger.info("獲取的導出類型為execl表格"+",每頁sheet導出的行數為:"+config_value+"行-------------------"); 
  4. File file = new File(new SimpleDateFormat("yyyy-MM-dd").format(new Date())+".xls"); 
  5. WritableWorkbook wbook = null ; WritableSheet wsheet =null
  6. wbook = Workbook.createWorkbook(file); //建立excel文件  
  7. long startTime = System.currentTimeMillis(); 
  8. try { 
  9. ExportToExcelSearchCondition condittion = ((ExportToExcelSearchCondition) ServletContext.currentSession().getAttribute("condittion")); 
  10. List<ContentToExcel> cte = new ArrayList<ContentToExcel>(); 
  11. if(condittion == null){ 
  12. throw new Exception("session獲取查詢條件失敗"); 
  13. }else
  14. //根據條件查詢需要導出的數據 
  15. cte = category2ContentDAO.searchByCondition(condittion.getCategoryId(), condittion.getHSDFlag(), 
  16. condittion.getExternalContentId(),condittion.getContentName(),condittion.getContentId(), condittion.getSystemId(), condittion.getState(), 
  17. condittion.getCpId(),condittion.getContentType(),condittion.getBeforemodifyTime(),condittion.getAftermodifyTime()); 
  18. logger.info("開始導出excel表格--"); 
  19. if(StringUtils.isNotBlank(config_value)){ 
  20. int value = NumberUtils.toInt(config_value); 
  21. if( cte !=null && cte.size()>0 ){ 
  22. int k = 0;//分sheet的個數 
  23. int i = 0;//用于循環Excel的行號 
  24. Iterator<ContentToExcel> it = cte.iterator();  
  25. Map<String,String> contentidAndContentTypeMap = new HashMap<String,String>();  
  26. Map<String,String> contentIdAndDurationMap= new HashMap<String,String>(); 
  27. for (ContentToExcel contentToExcel : cte) { 
  28. contentidAndContentTypeMap.put(contentToExcel.getContentId(), contentToExcel.getContentType()); 
  29. //計算時長 
  30. contentIdAndDurationMap = category2ContentDAO.getDurationByContentIdMap(contentidAndContentTypeMap); 
  31. /** 
  32. * 1)采用iterator迭代器進行迭代,與for循環相比可優化迭代效率。 
  33. * 2)大量數據影響效率,求大數據量的解決辦法。 
  34. * add by guohua.yuan 2013-06-08 
  35. */ 
  36. while(it.hasNext()){ 
  37. ContentToExcel contentToExcel = it.next(); 
  38. if( i % value == 0){ 
  39. wsheet = wbook.createSheet("節目單導出("+(int)(i/value+1)+")", (int)(i/value+1)); //工作表名稱  
  40. //設置Excel字體  
  41. WritableFont wfont = new WritableFont(WritableFont.ARIAL, 10, WritableFont.BOLD, false, jxl.format.UnderlineStyle.NO_UNDERLINE, jxl.format.Colour.BLACK);  
  42. WritableCellFormat titleFormat = new WritableCellFormat(wfont);  
  43. String[] title = { "標識","名稱""類型""碼流分檔""時長","快編人員" ,"初審人員","復審人員","終審人員","最后更新時間","內容創建時間","入庫時間","狀態"};  
  44. //設置Excel表頭  
  45. for (int j = 0; j < title.length; j++) {  
  46. Label excelTitle = new Label(j, 0, title[j], titleFormat);  
  47. wsheet.addCell(excelTitle);  
  48. }  
  49. k = k+1; 
  50. wsheet.addCell(new Label(0, i+1 -value*(k-1), contentToExcel.getContentId()));  
  51. wsheet.addCell(new Label(1, i+1 - value*(k-1), contentToExcel.getContentName())); 
  52. if(contentToExcel.getContentType().equals("Serie")){ 
  53. wsheet.addCell(new Label(2, i+1 - value*(k-1), "電視劇單集"));  
  54. }else if(contentToExcel.getContentType().equals("Series")){ 
  55. wsheet.addCell(new Label(2, i+1 - value*(k-1), "連續劇"));  
  56. }else if(contentToExcel.getContentType().equals("Movie")){ 
  57. wsheet.addCell(new Label(2, i+1 - value*(k-1), "電影"));  
  58. if(contentToExcel.getHSDFlag() == 1){ 
  59. wsheet.addCell(new Label(3, i+1 - value*(k-1), "標清"));  
  60. }else if(contentToExcel.getHSDFlag() == 2){ 
  61. wsheet.addCell(new Label(3, i+1 -value*(k-1), "高清"));  
  62. }else if(contentToExcel.getHSDFlag() == 3){ 
  63. wsheet.addCell(new Label(3, i+1 - value*(k-1), "超高清")); 
  64. //添加時長 
  65. wsheet.addCell(new Label(4, i+1 - value*(k-1),contentIdAndDurationMap.get(contentToExcel.getContentId())));  
  66. wsheet.addCell(new Label(5, i+1 - value*(k-1), contentToExcel.getKbPersonner()));  
  67. wsheet.addCell(new Label(6, i+1 - value*(k-1), contentToExcel.getCsPersonner()));  
  68. wsheet.addCell(new Label(7, i+1 - value*(k-1), contentToExcel.getFsPersonner()));  
  69. wsheet.addCell(new Label(8, i+1 - value*(k-1), contentToExcel.getZsPersonner()));  
  70. if(contentToExcel.getModifyTime()==null){ 
  71. wsheet.addCell(new Label(9, i+1 - value*(k-1), ""));  
  72. }else
  73. wsheet.addCell(new Label(9, i+1 - value*(k-1), new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(contentToExcel.getModifyTime())));  
  74. if(contentToExcel.getCreateTime() == null){ 
  75. wsheet.addCell(new Label(10, i+1 - value*(k-1), ""));  
  76. }else
  77. wsheet.addCell(new Label(10, i+1 - value*(k-1), new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(contentToExcel.getCreateTime())));  
  78. if(contentToExcel.getInstorageTime() ==null){ 
  79. wsheet.addCell(new Label(11,i+1 - value*(k-1),"")); 
  80. }else
  81. wsheet.addCell(new Label(11,i+1 - value*(k-1),new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(contentToExcel.getInstorageTime()))); 
  82. if(StringUtils.equals(contentToExcel.getStatus(), "1500")){ 
  83. wsheet.addCell(new Label(12, i+1 - value*(k-1), "成品就緒"));  
  84. }else if(StringUtils.equals(contentToExcel.getStatus(), "1700")){ 
  85. wsheet.addCell(new Label(12, i+1 - value*(k-1), "發布成功 "));  
  86. }else if(StringUtils.equals(contentToExcel.getStatus(), "1800")){ 
  87. wsheet.addCell(new Label(12, i+1 - value*(k-1), "發布失敗"));  
  88. }else if(StringUtils.equals(contentToExcel.getStatus(), "1901")){ 
  89. wsheet.addCell(new Label(12, i+1 - value*(k-1), "發布中"));  
  90. i++; 
  91. wbook.write();//寫入文件 
  92. }else
  93. throw new Exception("沒有數據可導"); 
  94. }else
  95. throw new Exception("請檢查系統配置管理是否配置導出類型的數據"); 
  96. catch (Exception e) { 
  97. throw new Exception(e); 
  98. }finally
  99. if(wbook!=null){ 
  100. wbook.close(); 
  101. logger.info("導出excel耗時:"+(System.currentTimeMillis() - startTime)+"ms"); 
  102. ServletContext.currentSession().removeAttribute("condittion"); 
  103. return new DownloadFile(file.getName()).readFrom(file); 

希望本文所述對大家jsp程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 固始县| 类乌齐县| 茌平县| 瓮安县| 太康县| 曲麻莱县| 成安县| 睢宁县| 牙克石市| 张北县| 绿春县| 吉木萨尔县| 呼图壁县| 虞城县| 嘉义县| 雅安市| 永嘉县| 二连浩特市| 镇安县| 旬邑县| 天全县| 盘山县| 北辰区| 闽清县| 靖远县| 曲阜市| 定西市| 阿克陶县| 石狮市| 黄石市| 永兴县| 惠东县| 龙州县| 寿宁县| 青浦区| 长乐市| 勐海县| 潞西市| 军事| 交口县| 南丰县|