a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > 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程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 久久国产香蕉视频 | 涩涩视频在线看 | 越南一级毛片免费 | 国产精品美女在线观看 | 瑟瑟在线观看 | 国产精品久久国产精品 | 在线一区观看 | 成年人网站免费在线观看 | 日本一区二区三区精品视频 | 蜜桃视频日韩 | 欧美一区 | 久久久久久久久久久网站 | www.亚洲| 黄色手机在线观看 | 国产黄色大片 | 国产在线专区 | 国产精品www | 国产成人精品在线 | 91亚洲精品一区 | 日韩视频在线一区二区 | 男女靠逼视频 | 免费xxxxx在线观看网站软件 | 麻豆精品一区二区 | 日韩欧美国产精品综合嫩v 狠狠综合久久 | 亚洲欧美另类在线 | 羞羞视频网站 | 欧美一二三区在线 | 色婷婷在线视频观看 | 在线久草 | 国产精品一区二区在线免费观看 | 国产www在线 | 日韩精品一区二区三区 | 色综合99| 18久久久久久 | av2014天堂网| 色黄视频在线看 | 国产成人a亚洲精品 | 天天干狠狠操 | 毛片在线看片 | 午夜精品久久久久久久久久久久 | 亚洲男人天堂2024 |