文档章节

使用FreeMark导出数据到Excle表格

你我青春时
 你我青春时
发布于 2014/06/04 14:43
字数 554
阅读 3640
收藏 0
点赞 0
评论 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 ⋅ 0

PHP 利用PHPExcel类库批量导出数据

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

黑夜探路人 ⋅ 2016/09/08 ⋅ 0

资源表 导出表结构导出表数据——JEPLUS快速开发平台

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

JEPLUS ⋅ 06/12 ⋅ 0

java 数据比对功能 求帮助

现在需要将数据库中查出来的的数据和excel中的数据做对比,如果数据库中 金额 字段的值 不等于 excle 金额列中对应的值 则将金额不一样的数据再导出Excle,,大致这样 各位大神有谁知道怎么做...

zsj2643 ⋅ 2016/10/18 ⋅ 9

Struts Ajax 导出Excel

下面讲解一种通过ajax请求,然后导出Excel的方法。 struts的配置如下: ExportExcelAction中的方法如下: 如此一来后台就准备就绪了。下面看看前台怎么做。 1,创建一个JS方法 2,然后可以通...

mybabe0312 ⋅ 2015/11/12 ⋅ 0

freeMark模板导出word

有时候我们会遇到将一些内容导出到word文档中方便查看,下面就来介绍下怎么采用freeMark模板导出为word。 一 . 工具准备 (1)这里我们需要用到notepad++这个工具,(下载链接https://notepad-p...

newdeng ⋅ 06/15 ⋅ 0

python自动化测试框架unittest+读取excel文件内容

写在前面:本人测试小白,自动化更是还没入门,业务逻辑也是随心所欲而分,若有高手路过,还望指点一二,不胜感激。 第一部分 ==========================================================...

不最醉不龟归 ⋅ 2016/11/08 ⋅ 0

POI 学习总结

最近做的模块需要一个导表的功能,以前也没使用过POI,所以写一个简单的学习总结,又错误的话欢迎各位大牛指正! 需求描述:调查问卷模块提供的调查结果下载,在项目中使用一个execel模版。 ...

王二铁 ⋅ 2012/02/01 ⋅ 0

java 用freemark导出excel 兼容 office excel 和 WPS 打开

java 中用freemark导出excel,导出后只能使用WPS打开文件,不能使用office excel打开,本地设置WPS兼容excel也不能行,求大神告知。怎样设置或是怎样做导出的文件才能 office excel和WPS都可...

呆萌萌呢 ⋅ 2016/11/08 ⋅ 3

Gridview导出Excle(无【xls格式与文件扩展名指定的格式不一致。】提示)

添加一个GvHelper类,使Gridview转为DataTable: using System;using System.Collections.Generic;using System.Text;using System.Web.UI.WebControls;using System.Data;using System.Web......

Akizi ⋅ 2014/02/20 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

Spring Cloud构建微服务架构—创建“服务注册中心”

创建一个基础的Spring Boot工程,命名为eureka-server,并在pom.xml中引入需要的依赖内容: <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-par......

itcloud ⋅ 3分钟前 ⋅ 0

拖动

<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>event</title> <style> #box { width: 100px; height: 100px; background-color: aquamarine; position: absolute; } </style......

fyliujj ⋅ 5分钟前 ⋅ 0

es6 polyfill array

polyfill之javascript函数的兼容写法——Array篇 1. Array.isArray(obj) if (!Array.isArray) { Array.isArray = function(arg) { return Object.prototype.toString.call(arg) === '[objec......

球球 ⋅ 7分钟前 ⋅ 0

kibana启动异常

检查一下:kibana.yml 每一对key:value中,冒号之后应有空格。

增删改查1 ⋅ 9分钟前 ⋅ 0

js修改img的src属性刷新图片时的图片缓存问题

问题:上传一张图片,通过js更新src属性刷新图片使其即时显示时, 当img的src当前的url与上次地址无变化时(只更改图片,名称不变,不同图片名称相同)图片不变化(仍显示原来的图片) 但通过...

HaierBrother ⋅ 9分钟前 ⋅ 0

Mysql

1.Jdbc Url 设置allowMultiQueries为true和false mysql的批量更新是要我们主动去设置的, 就是在数据库的连接url上设置一下,加上* &allowMultiQueries=true *即可。 参数名称 参数说明 缺省...

瑟青豆 ⋅ 12分钟前 ⋅ 0

mysql导出导入表结构与数据

当我们需要进行数据迁移时,mysql自带的mysqldump会是最好的方式。 1.导出某张表的结构和数据 首先,我们应当使用服务器,打开终端,连接到所需要导出的表所在的服务器上。执行命令: mysqld...

hengbao5 ⋅ 13分钟前 ⋅ 0

世界杯也走向“比拼”大数据的时代

《日本经济新闻》6月19日报道称,俄罗斯足球世界杯已于6月14日揭开战幕。作为第21次举办的足球世界杯,如何活用大数据有可能成为决定各支球队胜负的重要因素。从对阵球队的分析到战术建议,还...

加米谷大数据 ⋅ 13分钟前 ⋅ 0

金额转为千分制,金额转中文大写

金额转关为大写 js /** 数字金额大写转换(可以处理整数,小数,负数) */ function digitUppercase(n){ if(!n) reutrn "" let fraction = ['角', '分']; let digit = ['零', '壹', '贰', '叁', ...

YXMBetter ⋅ 16分钟前 ⋅ 0

开发利器JRebel部署SpringBoot项目

不要以为年纪轻轻就跌倒了人生谷底,未来还有更大的下降空间等着你。 idea下载和安装JRebel 激活JRebel 访问https://my.jrebel.com/ 使用facebook或twitter登录 勾选 Build project automati...

郑龙飞 ⋅ 22分钟前 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部