freemarker导出excel笔记

freemarker的使用方法

  1. 先用word/excel写一个模板文件,然后另存为xml
  2. 在线格式化,方便查看。将需要替换的位置用${}替换
  3. 将xml后缀修改为ftl,用于Freemarker处理
  4. 执行程序,使用map传入对应变量。最后生成doc或xls文件

word表格处理,只支持一行一行的数据处理

<<w:tbl>> 表格
<w: tr> 一行
<w: tc> 一列

ftl中的列表形式

<#list users as user>
  <p>${user}
</#list>

1.excel导出xml工作簿不包含任何xml映射

选择导出为Xml电子表格 .xml ,如下图所示。成功转化为xml形式
另存为xml电子表格

2.freemarker导出excel使用office打不开的解决办法(查看excel错误日志,修改对应错误)

第一步将excel后另存为xml格式后,再将xml后缀改为ftl,
导出功能做好后发现使用office打开excel报错,但是WPS正常打开,
查看excel错误日志(打开excel报错后会提示错误日志路径,你直接按路径去找是找不到的,直接C盘搜索日志名字就好)
原因可能为:
1、做模板的excel文件不是wps和office通用的版本,所以生成的excel文件office无法识别
2、模板文件为xml格式的时候,里面有些字段在office中无法识别。参考office报错日志信息修改
具体错误如下:


格式识别错误

在 表 出现 XML 错误
原因: 无效值
文件: ~\abc.xls
组: Table
标志: Row
ATTRIB: Index
值: 6

据查:是无法识别index和numberformat,暂时无法解决。只有先使用WPS打开,再另存为xls后,excel打开不会报错


报错显示工作簿设置错误

原因:ss:ExpandedRowCount 数值过小,Excel会检查设置的行数,如超过设置行数就会报错,把该值增大即可。或者动态监控:

比如:ss:ExpandedRowCount="${dataList?size + 10}"
dataList为数据集合

数据类型的错误:

<Data ss:Type="Number">序号</Data>1类型为数字,给的值却是字符串,也会导致office打不开
将Number改为String即可解决:<Data ss:Type="String">序号</Data>

参考文档
官方文档
freemarker生成excel、word、html、xml实例教程
freemarker导出excel时office报错而wps不会

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用freemarker生成word ,并集成struts2 同时生成及下载文档 资料附有Java源代码和自己总结的使用说明及注意事项 大至预览如下: 1、用word编辑好模板 普通字符串替换为 ${string} 格循环用标签 姓名:${user.userName} , 性别:${user.sex} 2、将word模板另存为xml格式 3、将xml模板文件后缀名改为.ftl 4、编辑ftl文件 注意 编辑word模板时,${string} 标签最好是手动一次性输入完毕,或者使用记事本统一将整个${string}编辑好之后,粘贴至word里边。 也就是说,不要在word里首先打完 ${ } 之后,又从其它地方把 string 字符串粘贴至 { } 之间,这样在 word 转化为 xml时,解析会有问题,freemarker解析时,会报错。 /** * @Desc:生成word文件 * @Author:张轮 * @Date:2014-1-22下午05:33:42 * @param dataMap word中需要展示的动态数据,用map集合来保存 * @param templateName word模板名称,例如:test.ftl * @param filePath 文件生成的目标路径,例如:D:/wordFile/ * @param fileName 生成的文件名称,例如:test.doc */ @SuppressWarnings("unchecked") public static void createWord(Map dataMap,String templateName,String filePath,String fileName){ try { //创建配置实例 Configuration configuration = new Configuration(); //设置编码 configuration.setDefaultEncoding("UTF-8"); //ftl模板文件统一放至 com.lun.template 包下面 configuration.setClassForTemplateLoading(WordUtil.class,"/com/lun/template/"); //获取模板 Template template = configuration.getTemplate(templateName); //输出文件 File outFile = new File(filePath+File.separator+fileName); //如果输出目标文件夹不存在,则创建 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(); } }

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值