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>
- java使用freemarker模版下载成Excel文件
- java使用freemarker模版导出分页word
- JAVA 使用FREEMARKER制作EXCEL
- freemarker 模版生成文件
- Java Excel文件下载
- Java下载Excel文件
- Java Web项目中使用Freemarker模版生成Word文档
- Java使用freemarker模版发送包含图片邮件
- JAVA使用POI根据模版导出EXCEL
- 使用freemarker制作邮件模版
- SpringMVC + Freemarker 模版的使用
- 实战Java模版引擎Freemarker
- java使用 freemarker 模板生成一个excel文件多个sheet
- java web实现excel模版下载功能(1)
- JXL Excel模版模版下载(1)
- jsp里使用java excel api实现文件下载
- java 下载样板Excel文件
- java 下载文件 例:excel
- 创建型--工厂方法模式
- 转]Android Parcelable和Serializable的区别,android parcelable
- Cadence基础知识6(cadence的allegro有5种类型的封装Mechanical Symbol及焊盘分类 )
- Android APP中清除缓存功能详解
- NOI2004 郁闷的出纳员
- java使用freemarker模版下载成Excel文件
- Redis源码包自带的服务启动脚本
- 面试杂谈
- ViewPager 实现引导页
- 抽象类
- 当我们谈起互联网企业时,我们在谈什么?
- python基础之删除文件及删除目录的方法
- Windows下FFmpeg快速入门
- Problem C