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

本文介绍如何利用jxls库处理Excel模板,包括依赖配置、数据填充及文件导出过程。通过实例展示了如何将数据集填充到Excel模板,并正确设置响应头以支持不同浏览器的下载。

 

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();
                      }

导出结果:


                     
               

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你好龙卷风!!!

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值