首页 > 编程 > 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程序设计有所帮助。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表