亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩国产综合新一区| 中文字幕日韩av综合精品| 欧美日韩国产成人高清视频| 欧美性猛交xxxx黑人猛交| 91av视频导航| 久久久久免费视频| www.亚洲一二| 最新亚洲国产精品| 国产亚洲人成a一在线v站| 国产男人精品视频| 亚洲男人天堂2023| 国产日韩欧美中文| 亚洲女人被黑人巨大进入al| 在线日韩av观看| 亚洲午夜av久久乱码| 成人午夜激情网| 国内精品小视频| 欧美日韩在线免费| 国产日韩换脸av一区在线观看| 5566日本婷婷色中文字幕97| 亚洲电影免费在线观看| 久久精品国产96久久久香蕉| 91精品国产九九九久久久亚洲| 久久艹在线视频| 国外日韩电影在线观看| 久久国产精品偷| 亚洲视频在线观看免费| 国产视频亚洲精品| 欧美黄色片免费观看| 久久久久久久久91| 国产在线一区二区三区| 91午夜在线播放| 亚洲成人久久久久| 亚洲综合精品伊人久久| 久久亚洲国产精品成人av秋霞| 亚洲精品98久久久久久中文字幕| 26uuu亚洲国产精品| 国产欧美日韩专区发布| 亚洲sss综合天堂久久| 亚洲一区二区三区乱码aⅴ| 日韩高清人体午夜| 国产精品大陆在线观看| 成人在线激情视频| 欧美另类极品videosbest最新版本| 亚洲国产欧美久久| 国产美女高潮久久白浆| 国产视频欧美视频| 国产一区二区三区免费视频| 亚洲自拍欧美另类| 欧美色另类天堂2015| 国产一区二区三区在线看| 欧美另类交人妖| 亚洲女同精品视频| 国产一区二中文字幕在线看| 美女福利精品视频| 亚洲视频在线播放| 欧美老少配视频| 亚洲国产精品国自产拍av秋霞| 亚洲老头老太hd| 一区二区三区国产视频| 一区二区三区 在线观看视| 黑人巨大精品欧美一区二区免费| 亚洲精品久久久久| 91免费欧美精品| 欧美乱妇高清无乱码| 在线电影欧美日韩一区二区私密| 国产精品日韩在线播放| 国产国语刺激对白av不卡| 久久精品中文字幕电影| 国产精品久久久久一区二区| 色偷偷9999www| 96sao精品视频在线观看| 国产成人一区二区在线| 国产精品日韩在线一区| 一本色道久久88精品综合| 国产精品爽黄69天堂a| 青青a在线精品免费观看| 日韩av在线免费观看| 91久久在线视频| 久久69精品久久久久久国产越南| 午夜精品久久久久久久久久久久久| 国产91在线高潮白浆在线观看| 国产在线观看91精品一区| 日韩专区在线观看| 8x拔播拔播x8国产精品| 亚洲美女久久久| 欧美成人免费va影院高清| 久久久久久久久久国产精品| 久久久久久久久久国产精品| 精品中文字幕久久久久久| 日韩视频在线一区| 亚洲第一精品自拍| 91精品久久久久久久久青青| 日韩成人久久久| 国产高清在线不卡| 成人免费视频网址| 久久久久久久久久国产| 性色av香蕉一区二区| 欧美人交a欧美精品| 亚洲国产成人91精品| 国产欧美一区二区三区在线| 国产精品丝袜久久久久久不卡| 日韩视频在线免费| 在线观看视频99| 成人综合网网址| 91精品久久久久久久久中文字幕| 91成人在线视频| 国产精品热视频| 亚洲国产欧美日韩精品| 国产精品啪视频| 亚洲国产精品女人久久久| 九九精品在线视频| 欧美成人精品xxx| 久久精品国产69国产精品亚洲| 国模吧一区二区| 影音先锋日韩有码| 久久久久久久久久久网站| 国产精品海角社区在线观看| 欧美丝袜第一区| 影音先锋日韩有码| 精品一区电影国产| 日韩视频精品在线| 久久精品国产精品亚洲| 久久久国产精品免费| 国内精品久久久久伊人av| 日韩av一区在线| 亚洲最大av在线| 国产精品麻豆va在线播放| 亚洲精品美女在线| 亚洲视频axxx| 精品国产网站地址| 久久人人爽人人爽人人片av高请| 亚洲国产黄色片| 亚洲精品suv精品一区二区| 国产精品久久久久久久9999| 久久久久久久色| 亚洲一区二区久久久久久| 亚洲国产成人精品久久| 亚洲欧美激情另类校园| 中文字幕在线亚洲| 色婷婷综合久久久久中文字幕1| 久久久999精品视频| www.午夜精品| 91免费高清视频| 亚洲精品国产精品久久清纯直播| 日韩电影在线观看永久视频免费网站| 久久久91精品国产| 欧美中文字幕视频在线观看| 亚洲精品资源美女情侣酒店| 欧美香蕉大胸在线视频观看| 国产精品99蜜臀久久不卡二区| 亚洲综合中文字幕在线| 国产一区二区丝袜高跟鞋图片| 日韩美女视频免费看| 欧美视频在线视频| 精品国产一区二区三区久久狼5月| 97久久精品人人澡人人爽缅北| 国产精品久久久久久网站| 91精品国产自产在线老师啪| 国产精品国模在线| 欧美性20hd另类| 欧美午夜xxx| 久久久999国产精品| 欧美日韩电影在线观看|