JXLS 利用自定义Excel模板导出excl

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/zhaofuqiangmycomm/article/details/83587829

mavn 依赖

<!-- XLSTransformer相关 -->

<dependency>

<groupId>net.sf.jxls</groupId>

<artifactId>jxls-core</artifactId>

<version>1.0.5</version>

</dependency>

<dependency>

<groupId>net.sf.jxls</groupId>

<artifactId>jxls-reader</artifactId>

<version>1.0.5</version>

</dependency>

<dependency>

<groupId>org.jxls</groupId>

<artifactId>jxls</artifactId>

<version>2.2.9</version>

</dependency>

<dependency>

<groupId>org.jxls</groupId>

<artifactId>jxls-poi</artifactId>

<version>1.0.15</version>

</dependency>

<dependency>

<groupId>org.jxls</groupId>

<artifactId>jxls-jexcel</artifactId>

<version>1.0.7</version>

</dependency>

Excel 模板例子:

                       List<ReportWorksheet> list = new  ArrayList<ReportWorksheet>();
                       reportWorksheetList.drainTo(list);
                         // 定义一个Map,往里面放入要在模板中显示数据
                        Map<String, Object> model = new HashMap<String, Object>();
                        model.put("reportWorksheetList", list);
                          //调用之前写的工具类,传入模板路径,输出流,和装有数据Map
                        //模板路径
                      //String  templateFileName=request.getSession().getServletContext().getRealPath("WEB-INF")+File.separator+"classes"+File.separator+"templates"+File.separator+"modules"+File.separator+"gen"+File.separator+"colleges.xls";
                      String  templateFileName=request.getSession().getServletContext().getRealPath("WEB-INF")+File.separator+"reportlets"+File.separator+"worksheetDetailReportTemplates"+File.separator+"exportHoBySevenDays.xls";
                      XLSTransformer transformer = new XLSTransformer();
                      try{
                          transformer.transformXLS(templateFileName, model, fileName);
                          //输入
                          BufferedInputStream bis = new BufferedInputStream(new FileInputStream(new File(fileName)));
                          //输出
                          BufferedOutputStream bos = new BufferedOutputStream(response.getOutputStream());

                          try {
                              // 中文文件名支持
                              String encodedfileName = null;
                              String agent = request.getHeader("USER-AGENT");

                              if (null != agent && -1 != agent.indexOf("MSIE")) {// IE
                                  encodedfileName = java.net.URLEncoder.encode(fileName, "UTF-8");
                              } else if (null != agent && -1 != agent.indexOf("Mozilla")) {
                                  encodedfileName = new String(fileName.getBytes("UTF-8"),"iso-8859-1");
                              } else {
                                  encodedfileName = java.net.URLEncoder.encode(fileName, "UTF-8");
                              }
                              response.setHeader("Content-Disposition", "attachment; filename=\""
                                      + encodedfileName + "\"");
                          } catch (UnsupportedEncodingException e) {
                              e.printStackTrace();
                          }

                          int byteRead = 0;
                          byte[] buffer = new byte[8192];
                          while ((byteRead = bis.read(buffer, 0, 8192)) != -1) {
                              bos.write(buffer, 0, byteRead);
                          }
                          bis.close();
                          bos.flush();
                          bos.close();
                      }catch (Exception e) {
                          e.printStackTrace();
                      }

导出结果:


                     
               

猜你喜欢

转载自blog.csdn.net/zhaofuqiangmycomm/article/details/83587829