文档章节

使用FreeMark导出数据到Excle表格

你我青春时
 你我青春时
发布于 2014/06/04 14:43
字数 554
阅读 3767
收藏 0

一、使用freemarker时需要的jar包:freemarker-2.3.19.jar。

二、根据需求做出导出模板

  1. 做出Excle模板

    这个没什么说的,直接按照需求做出Excle模板,如下:(这里建议用Excle,别用WPS。后面转存为XML文件时容易报错)

    在Excle里面,建议加上如上图的${list.aa},list为需要遍历的变量,aa为遍历后VO里面的字段,方便在转存后的XML里面找到


  2. 修改扩展名为ftl,在ftl里面加上 遍历的标签和变量


三、获取需要导出的数据

可以由前台传回sql筛选条件,在后台拼接后。进行查询数据。

在获得相应的list数据后,放入map

//将资产list放入map
@SuppressWarnings("rawtypes")
Map dataMap = new HashMap<String, List<Lessee>>();
dataMap.put("size", String.valueOf(size));//size是后面提到的表格的初始行数
dataMap.put("list", list);//list 传入模板的list
//编写在Excel里面对应的变量
           
                //模版名称
                        String templateName = "exlessee.ftl";
                        //导出文件的名称
    String exportWord = application.getRealPath("template") + DateUtil.getDateNow("yyyyMMddHHmmss") + ".xls";
                        
                        
                        exportWord(templateName, dataMap, exportWord, "xxx.xls");

四、封装的exportWord方法

/**
      * 导出的工具方法
      */
     
     public void exportWord(String templatePath, Map<String, Object> dataMap,
                String buildFile, String newName)
        {
            try
            {
                Configuration configuration = new Configuration();
                configuration.setDefaultEncoding("utf-8");
                String path = application.getRealPath("template");
                configuration.setDirectoryForTemplateLoading(new File(path));//此处是本类Class.getResource()相对于模版文件的相对路径
                Template template = null;
                File outFile = new File(buildFile);
                Writer writer = null;
                template = configuration.getTemplate(templatePath);
                template.setEncoding("utf-8");
                writer = new BufferedWriter(new OutputStreamWriter(
                        new FileOutputStream(outFile), Charset.forName("utf-8")));//此处为输 出文档编码
                template.process(dataMap, writer);
                writer.flush();
                writer.close();

//                return true;
                
                //设置response的编码方式
                response.setContentType("application/x-msdownload");
                //设置附加文件名
                response.setHeader("Content-Disposition", "attachment;filename="
                        + new String(newName.getBytes("gbk"), "iso-8859-1"));

                //读出文件到i/o流
                FileInputStream fis = new FileInputStream(outFile);
                BufferedInputStream buff = new BufferedInputStream(fis);

                byte[] b = new byte[1024];//相当于我们的缓存

                long k = 0;//该值用于计算当前实际下载了多少字节

                //从response对象中得到输出流,准备下载

                OutputStream myout = response.getOutputStream();

                //开始循环下载

                while (k < outFile.length())
                {

                    int j = buff.read(b, 0, 1024);
                    k += j;

                    //将b中的数据写到客户端的内存
                    myout.write(b, 0, j);

                }

                //将写入到客户端的内存的数据,刷新到磁盘
                myout.flush();
                myout.close();

            } catch (Exception e)
            {
                
                e.printStackTrace();
//                return false;
            }
        }


© 著作权归作者所有

你我青春时
粉丝 1
博文 20
码字总数 2690
作品 0
武汉
后端工程师
私信 提问
Weblogic 配置问题

把代码上传到weblogic 服务器上时,出现了一个路径问题,求各位大神帮忙解决。 项目有一个功能是把查询的数据导出excle表格,用了ireport的jasper,在本地上跑的时候可以正常导出excle表格,但...

Expectation
2014/06/16
101
0
python项目实战:简单操作excle表的方法

前言 Python操作Excle文件:使用xlwt库将数据写入Excel表格,使用xlrd 库从Excel读取数据。这篇文章主要介绍了python简单操作excle的方法,Python操作Excle文件:使用xlwt库将数据写入Excel表...

Python学习1
05/08
31
0
PHP 利用PHPExcel类库批量导出数据

之前做健康档案系统时,有一个将统计的数据批量导出到Excel的需求,后来实现后就没怎么做记录,最近一个小伙伴问我这块的问题,我觉得有必要将这块的东西写下来和大家分享和学习下,这段时间...

黑夜探路人
2016/09/08
97
0
资源表 导出表结构导出表数据——JEPLUS快速开发平台

JEPLUS资源表 如何导出表结构导出表数据 平时开发过程中我们使用平台与数据库进行交互的过程中很多时候会用到需要导出表结构或者导出表数据,尤其是涉及到迁库或者提取表数据的情况,平台考虑...

JEPLUS
2018/06/12
17
0
Java +EasyUI+SpringMvc实现Excle导入导出(上)

前言 先介绍下项目的开发环境,采用java开发语言进行开发,前台UI使用的是EasyUI框架,接下来是SpringMvc与Ejb结合来开发,整个项目管理采用的是Maven管理,服务器用的是Jboss6.2.0企业版。 ...

fightingKing
2015/01/26
0
0

没有更多内容

加载失败,请刷新页面

加载更多

EDI 电子数据交换全解指南

EDI(Electronic Data Interchange,电子数据交换)技术使得企业与企业(B2B)实现通信自动化,帮助交易伙伴和组织更快更好地完成更多工作,并消除了人工操作带来的错误。从零售商到制造商、物...

EDI知行软件
58分钟前
3
0
CentOS7的LVM动态扩容

# 问题 CentOS7上面的磁盘空间有点紧张,需要扩容。 解决 查询当前磁盘状态 [root@xxx ~]# lsblkNAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINTfd0 2:0 1 4K ...

亚林瓜子
今天
3
0
Kafka 0.8 Producer (0.9以前版本适用)

Kafka旧版本producer由scala编写,0.9以后已经废除 示例代码如下: import kafka.producer.KeyedMessage;import kafka.javaapi.producer.Producer;import kafka.producer.ProducerConfig;......

实时计算
今天
4
0
Giraph源码分析(八)—— 统计每个SuperStep中参与计算的顶点数目

作者|白松 目的:科研中,需要分析在每次迭代过程中参与计算的顶点数目,来进一步优化系统。比如,在SSSP的compute()方法最后一行,都会把当前顶点voteToHalt,即变为InActive状态。所以每次...

数澜科技
今天
6
0
Navicat 快捷键

操作 结果 ctrl+q 打开查询窗口 ctrl+/ 注释sql语句 ctrl+shift +/ 解除注释 ctrl+r 运行查询窗口的sql语句 ctrl+shift+r 只运行选中的sql语句 F6 打开一个mysql命令行窗口 ctrl+l 删除一行 ...

低至一折起
今天
13
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部