java使用freemarker模版下载成Excel文件

来源:互联网 发布:美工工资 编辑:程序博客网 时间:2024/05/20 06:26

下载整个过程:通过已有的Excel模版,前台显示的某些变量通过后台传到模版中,在后台系统自动组装下载路径和下载名,此下载有一个缺陷就是不能够在页面选择下载路径。

实现过程:

  1.建立模版

        (1)如果要下载的是word,首先通过word建立模版;如果要下载的是Excel,首先通过Excel建立模版。

        (2)将里边的变量使用${变量名}代替

        (3)另存为以后缀.xml的格式(这里要注意:如果转成xml之后,里边有${&**&*&8%$变量名**************}的,则需去掉多余的保证freemarker标签完整的前提下将这里改为${变量名}

        (4)将xml后缀改为ftl后缀

 2.在工程中加入freemarker.jar

 3.在工程中加入以下代码

        1)将变量的值存入map中:

    

/** 用于组装word页面需要的数据 */
            Map<String, Object> dataMap = new HashMap<String, Object>();
            /** 组装数据 */
            SimpleDateFormat sdf=new SimpleDateFormat("yyyy年MM月dd日");
            dataMap.put("currentday",sdf.format(new Date()));
            dataMap.put("jhxf",jhxf);
            dataMap.put("jhyf",map.get("jhyf"));
            dataMap.put("jksz",map.get("jksz") );
            dataMap.put("jhxfse", map.get("jhxfse"));
            dataMap.put("ldjxbd", ldjxbd);
            dataMap.put("ldbdse", map.get("ldbdse"));
            dataMap.put("jhyc", jhyc);
            dataMap.put("jhycse", map.get("jhycse"));
            dataMap.put("dwmc", map.get("dwmc"));
            dataMap.put("swjg", map.get("swjg"));
            dataMap.put("jssbyf", map.get("jssbyf"));
            dataMap.put("nsrsbh", map.get("nsrsbh"));

       2)组装文件的文件名(每次的文件名都不一样)

           /** 文件名称,唯一字符串 */
            Random r=new Random();
            SimpleDateFormat sdf1=new SimpleDateFormat("yyyyMMdd_HHmmss_SSS");
            StringBuffer sb=new StringBuffer();
            sb.append(sdf1.format(new Date()));
            sb.append("_");
            sb.append(r.nextInt(100));

         3)设置保存路径

            //文件路径
            filePath="F:/HGJKS_tzsxz";
            //文件唯一名称
            fileOnlyName = "exportWord_"+sb+".xls";
            /** 生成word */

  }

          4)生成word


try {
                //创建配置实例
                Configuration configuration = new Configuration();
                //设置编码
                configuration.setDefaultEncoding("UTF-8");
                //ftl模板文件统一放至 com.lun.template 包下面
                configuration.setClassForTemplateLoading(WordUtil.class,"/com/foresee/hgjks/front/template");
                //获取模板
                Template template = configuration.getTemplate("zzstzsqr.ftl");
                //输出文件
                File outFile = new File(filePath+File.separator+fileOnlyName);
                //如果输出目标文件夹不存在,则创建
                if (!outFile.getParentFile().exists()){
                    outFile.getParentFile().mkdirs();
                }
                //将模板和数据模型合并生成文件
                Writer out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(outFile),"UTF-8"));
                //生成文件
                template.process(dataMap, out);
                //关闭流
                out.flush();
                out.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }


******************如果有要遍历的列表*******************

  java代码中:  

    1.定义一个list

    2.将list放入要存的map里边

   freemarker中:

     给要遍历的地方加上<#list></#list>

<#list xflist as xftest>----xflist是java中map里边的要遍历的list,xftest是别名。

  遍历的时候${xftest.xfxh}。

整体如下:

<#list xflist as xftest>
   <Row ss:Height="14.25">
    <Cell ss:StyleID="s64"><Data ss:Type="String">${xftest.xfxh}</Data></Cell>
    <Cell ss:StyleID="s65"><Data ss:Type="String">海关缴款书</Data></Cell>
    <Cell ss:StyleID="s65"><Data ss:Type="String">-</Data></Cell>
    <Cell ss:StyleID="s64"><Data ss:Type="String">${xftest.xfpzhm}</Data></Cell>
    <Cell ss:StyleID="s65"><Data ss:Type="String">-</Data></Cell>
    <Cell ss:StyleID="s64"><Data ss:Type="String">${xftest.xfkjrq}</Data></Cell>
    <Cell ss:StyleID="s65"><Data ss:Type="String">-</Data></Cell>
    <Cell ss:StyleID="s64"><Data ss:Type="String">${xftest.xfse}</Data></Cell>
   </Row>
</#list>




0 0