在生成Excel的时候,大多时候都是使用poi,jxl等进行的,但是对于复杂的Excel来说,这个工作量是非常的大的,而且,对于我这么懒的人来说,这是相当痛苦的一件事情,所以,我不得不找找有没有简单一点的办法来搞定这个事情。我想到了上次用freemarker成功生成了Word文档。我就想可不可以也生成Excel呢?然后我就尝试。结果真行,不过,和生成Word文档有一些差别,好了,不废话了,上图。

上一张比较简单的Excel图。

这个,就是Excel的一个结构了,接下了,将它另存为“XML 电子表格2003(*.xml)”

至如如何将数据准确的填充到相应的地方,看上一篇生成Word文档的小技巧,就是在需要填充数据的地方加上一个标记,或者写拼音。

下图是生成的Xml

我想,这个结构大家应该能一目了然了,row:代表一行,cell代表一个单元格.

用过poi,jxl的朋友应该非常的熟悉了.

有的朋友可能打开的时候,xml非常的凌乱,找不到需要修改的地方,上面所说的小技巧就起到了作用,按照拼音或者你独特的标识找到需要修改的位置.

在需要填充数据的地方写上freemarker模块语句。例如:将类型改为"${type}" ,双引号别也拷贝过去了,呵呵.

还有,这一行可能有很多行,所有需要一个迭代的标签,在上一篇我也说到过的.

<#list sequence as item>

</#list>

上面的语法格式中,sequence就是一个集合对象,也可以是一个表达式,但该表达式将返回一个集合对象,

而item是一个任意的名字,就是被迭代输出的集合元素.此外,迭代集合对象时,还包含两个特殊的循环变量:
item_index:当前变量的索引值
item_has_next:是否存在下一个对象
也可以使用<#break>指令跳出迭代

其实这些在http://www.havenliu.com/goodarticle/420.html里面都是有的,有时间的朋友可以看看.有许多有意思的东西.

回到正题,将你需要循环遍历的一行剪切到<#list></#list>中间.

好,做完这一步,就可以将它的后缀名改为:ftl了。

工作做到这一步已经差不多了,代码的话,可以看上一篇.算了,负点责任,将代码贴上并写一些注释吧.

  1. package com;
  2. import java.io.BufferedWriter;
  3. import java.io.File;
  4. import java.io.FileNotFoundException;
  5. import java.io.FileOutputStream;
  6. import java.io.IOException;
  7. import java.io.OutputStreamWriter;
  8. import java.io.Writer;
  9. import java.util.ArrayList;
  10. import java.util.HashMap;
  11. import java.util.List;
  12. import java.util.Map;
  13. import freemarker.template.Configuration;
  14. import freemarker.template.Template;
  15. import freemarker.template.TemplateException;
  16. public class WordTest {
  17. private Configuration configuration = null;
  18. public WordTest(){
  19. configuration = new Configuration();
  20. configuration.setDefaultEncoding("UTF-8");
  21. }
  22. public static void main(String[] args) {
  23. WordTest test = new WordTest();
  24. test.createWord();
  25. }
  26. public void createWord(){
  27. Map<String,Object> dataMap=new HashMap<String,Object>();
  28. getData(dataMap);
  29. configuration.setClassForTemplateLoading(this.getClass(), "/com");  //FTL文件所存在的位置
  30. Template t=null;
  31. try {
  32. t = configuration.getTemplate("wordModel.ftl"); //文件名
  33. } catch (IOException e) {
  34. e.printStackTrace();
  35. }
  36. File outFile = new File("O:/outFilessa"+Math.random()*10000+".xls");  //生成文件的路径
  37. Writer out = null;
  38. try {
  39. out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(outFile)));
  40. } catch (FileNotFoundException e1) {
  41. e1.printStackTrace();
  42. }
  43. try {
  44. t.process(dataMap, out);
  45. } catch (TemplateException e) {
  46. e.printStackTrace();
  47. } catch (IOException e) {
  48. e.printStackTrace();
  49. }
  50. }
  51. //这里赋值的时候需要注意,xml中需要的数据你必须提供给它,不然会报找不到某元素错的.
  52. private void getData(Map<String, Object> dataMap) {
  53. dataMap.put("title", "标题");
  54. dataMap.put("year", "2012");
  55. dataMap.put("month", "2");
  56. dataMap.put("day", "13");
  57. dataMap.put("auditor", "鑫");
  58. dataMap.put("phone", "xxxxxxxxxxxxx");
  59. dataMap.put("weave", "文涛");
  60. //      dataMap.put("number", 1);
  61. //      dataMap.put("content", "内容"+2);
  62. List<Map<String,Object>> list = new ArrayList<Map<String,Object>>();
  63. for (int i = 0; i < 10; i++) {
  64. Map<String,Object> map = new HashMap<String,Object>();
  65. map.put("number", i);
  66. map.put("content", "内容"+i);
  67. list.add(map);
  68. }
  69. dataMap.put("list", list);
  70. }
  71. }

好了,大致就这样了.

如何程序没报错的话,那么你的Excel已经成功生成出来了,但是.

有时候会打不开?表出错?

这是因为Excel在生成xml的时候,可能是为了不浪费资源吧,在生成时候,会指定Excel有多少行,如果超出了这个长度的话,它就会编译不通过.报错.

问题很好解决.

针对这2个问题,需要修改2个不同的地方.

1:工作表的到设置.就是Sheet了.ok,打开xml,搜索"Worksheet",如果你有多个工作表的话,找到你自己要的.

修改它的属性值"ss:ExpandedRowCount",看到这,应该懂了吧?把它设置大一点,或者通过程序传个值给它也可以.这个问题就解决了.

2:表,如果你有耐性,可以根据它给你的log去看看,一看也就知道了.不过不是很好找,呵呵.

搜索最后一个Row,修改它的属性值"ss:Index".

JAVA用freemarker生成复杂Excel。(freemarker)的更多相关文章

  1. java利用poi生成/读取excel表格

    1.引入jar包依赖 <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi< ...

  2. java使用poi生成导出Excel(新)

    导出样式: java代码: import java.io.FileOutputStream; import java.io.IOException; import java.io.OutputStre ...

  3. java后台动态生成导出excel

    p ublic void export(List<WechatUser> wechatUserList, HttpServletResponse response) throws IOEx ...

  4. java将HSSFWorkbook生成的excel压缩到zip中

    思路:1.写入输入流中. 2.将输入流加到ZipOutputStream压缩流中 List<DocumentModel> list = null; try { list = documen ...

  5. JavaWeb开发中采用FreeMarker生成Excel表格

            最近做了一个需求,要求导出一个采购合同的Excel表格,这个表格样式比较多.由于是合同,这个Excel表格里面有好多格式要求,比如结尾处签字那部分就有格式要求.这里介绍种采用FreeM ...

  6. FreeMarker 生成Java、mybatis文件

    FreeMarker 生成Java.mybatis文件 将mysql数据库表通过FreeMarker生成对应的Java文件和对应的mybatis文件. FreeMarker是一款模板引擎: 即一种基于 ...

  7. java使用freemarker生成静态html页面

    1. 模板文件static.html <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" " ...

  8. java使用freemarker 生成word文档

      java 生成word文档     最近需要做一个导出word的功能, 在网上搜了下, 有用POI,JXL,iText等jar生成一个word文件然后将数据写到该文件中,API非常繁琐而且拼出来的 ...

  9. java用freemarker实现导出excel

    前几天做了jxl导出excel,现在用freemarker做一下 freemarker导出excel和导出word步骤和是实现方法是相同的. 1.制作excel模板 2.将后缀名改为ftl,放到对应的 ...

随机推荐

  1. 斯坦福CS231n—深度学习与计算机视觉----学习笔记 课时14&&15

    课时14 卷积神经网络详解(上) CNN处理的是一些数据块,在这之间有很多层,一系列的层将输入数据变换为输出数据,所以完成操作的中间量不仅是NN时候讲的那些向量,而是立体结构,有宽,高和深度,在整个计 ...

  2. 【CodeForces - 651C 】Watchmen(map)

    Watchmen 直接上中文 Descriptions: 钟表匠们的好基友马医生和蛋蛋现在要执行拯救表匠们的任务.在平面内一共有n个表匠,第i个表匠的位置为(xi, yi). 他们需要安排一个任务计划 ...

  3. PHP 遍历一个文件夹下所有文件和子文件夹的方法

    话不多说,直接上代码 <?php function my_dir($dir) { $files = []; if(@$handle = opendir($dir)) { while(($file ...

  4. Solutions to an Equation LightOJ - 1306

    Solutions to an Equation LightOJ - 1306 一个基础的扩展欧几里得算法的应用. 解方程ax+by=c时,基本就是先记录下a和b的符号fla和flb(a为正则fla为 ...

  5. linux中用户组和用户

    linux中用户组和用户 1.介绍 在我们的linux系统,有很多用户组,也可以手动创建用户组,不同的用户组下面有很多的用户. 2.创建用户组及有关的命令 groupadd phpzu:创建一个php ...

  6. Contextual Action bar(3) 两个示例

    一.通过activity启动Context Action Bar 1.主java public class ActivityActionModeFrgmt extends Fragment imple ...

  7. 正则表达式exec方法的陷阱

    http://www.w3school.com.cn/jsref/jsref_exec_regexp.asp exec() 方法的功能非常强大,它是一个通用的方法,而且使用起来也比 test() 方法 ...

  8. Java三大特性之---封装

    封装从字面上来理解就是包装的意思,专业点就是信息隐藏,是指利用抽象数据类型将数据和基于数据的操作封装在一起,使其构成一个不可分割的独立实体,数据被保护在抽象数据类型的内部,尽可能地隐藏内部的细节,只保 ...

  9. PHP连接数据操作步骤

    数据库的操作步骤: 端口号:0到65535 3306:mysql数据库的默认端口号(可修改) mysql_connect(“本机地址”,“用户名”,“密码”,); new_link:如果用同样的参数第 ...

  10. AJPFX总结方法重载与方法重写的区别

    方法重载在同一个类中,可以出现同名方法,但是这些同名方法的参数列表必须不同,这样定义方法叫做方法重载.方法重载的特点重载的注意事项重载与返回值无关重载与具体的变量标识符无关重载只与方法名与参数相关重载 ...