将数据以Excel表格的形式导出:
首先下载poi的jar包,导入项目中,或者使用maven仓库管理,在pom文件添加:
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>3.9</version>
</dependency>

前端代码:
页面上定义下载/导出按钮,点击按钮时下载/导出,如:
<button class="" id="exportDate" onclick="exportDate()">下载/导出</button>

function exportDate(){
    var url="";    //路径
    window.open(url);
}
后端代码:
Controller层:
@RequestMapping(value="/exportDate",method=RequestMethod.GET)
public void exportDate(需要接受的参数/条件,HttpServletResponse response) throws Exception{
    //如涉及权限/级别/条件等,先进行判断;
    //根据条件等查询要导出的数据
    List<Object> list = 查询要导出的数据;
    //可先判断要导出的数据的数量来确定使用HSSFWorkbook工具类或者SXSSFWorkbook工具类
    if(list.size()>60000){
        list = list.subList(0,60000);
    }
    //将数据放入HSSFWorkbook对象中
    HSSFWorkbook wb = xxxService.getWb(list);
    //大数据量时使用SXSSFWorkbook工具类
    //SXSSFWorkbook wb = xxxService.getWb(list);
    //定义导出的表名
    String fileName = URLEncoder.encode("表名"+".xls","UTF-8");
    ByteArrayOutputStream os = new ByteArrayOutputStream();
    wb.write(os);
    if(os.size() > 0){
        response.setContentType("application/octet-stream");
        response.addHeader("Content-Disposition","attachment;filename="+fileName);
        response.addHeader("Content-Length",""+os.size());
        IOUtils.write(os.toByteArray(),response.getOutputStream());
        response.getOutputStream().flush();
    }
    os.close();
}

获取HSSFWorkbook/SXSSFWorkbook工具类对象的方法,可写在service层
一、HSSFWorkbook工具类(导出.xls格式文件)
HSSFWorkbook对象,最多支持65535行,适用一般数据量少导出
//适用公共方法获取表单元格标题
public HSSFWorkbook getWb(List<Object> list) throws Exception{
    //创建对象
    HSSFWorkbook wb = new HSSFWorkbook();
    //创建一个sheet
    HSSFSheet sheet = wb.createSheet("sheet名");
    //添加表头
    HSSFRow row = sheet.createRow((int)0);
    //单元格样式
    HSSFCellStyle style = wb.createCellStyle();
    style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
    HSSFCell cell = row.createCell(0);
    //创建公共工具类对象
    Utils util = new Utils();
    //调用方法获得标题
    Map<String,String> map = util.getBeanComment("实体类路径");
    int i=0;
    for (String key : map.keySet()) {
        cell = row.createCell(i);
        cell.setCellValue(map.get(key));
        cell.setCellStyle(style);
        i++;
    }
    i=0;
    for (Object obj:list) {
        row = sheet.createRow((int) i + 1);
        int j=0;
        for (String key : map.keySet()) {
            cell=row.createCell(j);
            cell.setCellValue(BeanUtils.getProperty(obj,key));
            j++;
        }
        i ++ ;
    }
    return wb;
}

二、SXSSFWorkbook工具类(导出.xlsx格式文件,适用于数据量大的文件导出)
SXSSFWorkbook对象,只支持.xlsx格式。它就是用来解决大数据量以及超大数据量的导入导出操作的,
单个sheet表就支持近104万条数据了。要是导出104万以上的数据,这时我们必须拆分到多个工作表来实现。
//以数组的方式手动定义表单元格标题和对应值
public SXSSFWorkbook getWb(String sheetName,String[] title,String[][] values){
    //内存中只创建100个临时对象,超过100个将释放不用对象
    SXSSFWorkbook wb = new SXSSFWorkbook(100);
    //工作表对象
    Sheet sheet = null;
    //行对象
    Row row = null;
    //列对象
    Cell cell = null;
    int rowNo = 0;
    int pageRowNo = 0;
    //表单样式风格
    CellStyle style = wb.createCellStyle();
    style.setAlignment(CellStyle.ALIGN_CENTER);
    if(values != null && values.length>0){
        for(int j=0;j<values.length;j++){
            //超过一百万行后换一个工作薄,单个sheet最多1048576行
            if(rowNo%1000000 == 0){
                sheet = wb.createSheet("第"+(rowNo/1000000+1)+"个工作薄");
                sheet = wb.getSheetAt(rowNo/1000000);
                pageRowNo = 0;
            }
            rowNo++;
            //创建标题
            if(pageRowNO == 0){
                row = sheet.createRow(0);
                for(int i=0;i<title.length;i++){
                    cell = row.createCell(i);                         
                    cell.setCellValue(title[i]);                      
                    cell.setCellStyle(style);
                    if(i==title.length-1){
                        sheet.setDefaultColumnWidth(20);
                    }
                }
            }else{
                //创建行
                row = sheet.createRow(pageRowNo);
                for(int k=0;k<values[j].length;k++){
                    // 创建列  
                    cell = row.createCell(k);
                    if(k == 0){
                        //对列进行赋值  
                        cell.setCellValue(Long.parseLong(values[j][k]));
                    }else{
                        if(numType(values[j][k])){
                            cell.setCellValue(Double.parseDouble(values[j][k]));
                        }else{
                            cell.setCellValue(String.valueOf(values[j][k]));
                        }
                    }
                    cell.setCellStyle(style);
                }
            }
            pageRowNo++;
        }
    }
    return wb;
}

如果用一中公共工具类的getBeanComment()方法,如下:
public Map<String,String> getBeanComment(String bean){
    Map<String,String> map = new HashMap<>();
    try{
        Class clz = Class.forName(bean);
        Field[] strsSub = clz.getDeclaredFields();
        Class clzSuper = Class.forName(bean).getSuperclass();
        List<Field> strs = new ArrayList<>();
        for(Field filed : strsSub){
            strs.add(filed);
        }
        if(null != clzSuper){
            Field[] StrsSuper = clzSuper.getDeclaredFields();
            for(Field field : StrsSuper){
                strs.add(field);
            }
        }
        //StringBuffer sb = new StringBuffer();
        for(Field field : strs){
            Comment comment = field.getAnnotation(Comment.class);
            if(null == comment){
                continue;
            }
            String name = field.getName();
            if("id".equals(name)){
                continue;
            }
            if(StringUtils.isNotBlank(comment.value())){
                map.put(name, comment.value());
            }
        }
        return map;
    }catch(ClassNotFoundException e) {
        e.printStackTrace();
        return null;
    }
}

注:
可参考:https://blog.csdn.net/runzhisheng114/article/details/75303750;
        https://blog.csdn.net/u014621859/article/details/54944059;

Java导出Excel文件的两种方法的更多相关文章

  1. .NET CORE 2.1 导出excel文件的两种方法

    最近在做 MVC 项目的时候遇到项目的导出,下面总结下两种导出到excel 的方法 第一种方法: 将文件写到本地,然后返回这个File 或者返回这个 File 的绝对地址  其中  _hostingE ...

  2. web导出excel文件的几种方法

    总的来说,两种方法:服务器端生成和浏览器端生成. 服务器端生成就是:根据用户请求,获取相应的数据,使用poi/jxl, jacob/jawin+excel,或是用数据拼html的table或是cvs纯 ...

  3. Java读取Excel文件的几种方法

    Java读取 Excel 文件的常用开源免费方法有以下几种: 1. JDBC-ODBC Excel Driver 2. jxl.jar 3. jcom.jar 4. poi.jar 简单介绍: 百度文 ...

  4. [转载]Java操作Excel文件的两种方案

    微软在桌面系统上的成功,令我们不得不大量使用它的办公产品,如:Word,Excel.时至今日,它的源代码仍然不公开已封锁了我们的进一步应用和开发.在我们实际开发企业办公系统的过程中,常常有客户这样子要 ...

  5. mysql导出excel文件的几种方法

    方法一 用mysql的命令和shell select * into outfile './bestlovesky.xls' from bestlovesky where 1 order by id d ...

  6. 读取Excel文件的两种方法

    第一种方法:传统方法,采用OleDB读取EXCEL文件, 优点:写法简单,缺点:服务器必须安有此组件才能用,不推荐使用 private DataSet GetConnect_DataSet2(stri ...

  7. 读取Excel文件的两种方法比较 以及用NPOI写入Excel

    1. 采用NPOI方式,只需引用NPOI.dll,但目前最高只能到2.4.0版. 缺点:只支持.xls,不支持.xlsx格式.github上的2.4.1版支持.xlsx,但总提示缺ICSharpCod ...

  8. Oracle导出DMP文件的两种方法

    本文转载自:http://www.cnblogs.com/o-andy-o/archive/2013/06/05/3118611.html   导出: 方法一:利用PL/SQL Developer工具 ...

  9. java读取excel文件的两种方式

    方式一: 借用 package com.ij34.util; /** * @author Admin * @date 创建时间:2017年8月29日 下午2:07:59 * @version 1.0 ...

随机推荐

  1. _markupbase.py if not match: UnboundLocalError: local variable 'match' referenced before assignment,分析Python 库 html.parser 中存在的一个解析BUG

    BUG触发时的完整报错内容(本地无关路径用已经用 **** 隐去): **************\lib\site-packages\bs4\builder\_htmlparser.py:78: U ...

  2. UOJ #131 BZOJ 4199 luogu P2178【NOI2015】品酒大会 (后缀自动机、树形DP)

    水是水,但是写出了不少问题,因此写一发博客. https://www.luogu.org/problemnew/show/P2178 https://www.lydsy.com/JudgeOnline ...

  3. CLR与Netframework版本的关系

    CLR有3个版本,详细地址看微软官方文档

  4. win7/WIN8.1(x64) 下使用MSDE WIN10不行

    通过强制安装(使用管理员权限),手工启动服务的方式,能够在其win7 win81上安装并使用MSDE Microsoft SQL Server 2000 Service Pack 4 Desktop ...

  5. 初步了解Shuttle ESB

    ESB:EnterpriseService Bus,即企业服务总线.它是传统中间件技术与XML.Web服务等技术结合的产物.从面向服务体系架构发展而来. ESB採用了"总线"这种模 ...

  6. 扩展函数之 IsWhat 简单好用

    代码实现: /***扩展函数名细***/ //[IsInRange] ; //以前写法 & num < ) { } //现在写法 , )) { } //datetime类型也支持 //[ ...

  7. nyoj--105--九的余数(水题)

    九的余数 时间限制:3000 ms  |  内存限制:65535 KB 难度:3 描述 现在给你一个自然数n,它的位数小于等于一百万,现在你要做的就是求出这个数整除九之后的余数. 输入 第一行有一个整 ...

  8. 第19章 Redis的一些常用技术

    19.1 Redis的基础事务                       图19-1 Redis命令执行事务的过程                      19-1:在Spring中使用Redis ...

  9. [WebServer] Linux下Apache与Tomcat整合的简单方法

    Apache与Tomcat比较联系 apache支持静态页,tomcat支持动态的,比如servlet等. 一般使用apache+tomcat的话,apache只是作为一个转发,对jsp的处理是由to ...

  10. Linux Shell Scripting Cookbook 读书笔记 1

    本系列文章为<Linux Shell Scripting Cookbook>的读书笔记,只记录了我觉得工作中有用,而我还不是很熟练的命令 书是很好的书,有许多命令由于我比较熟悉,可能就没有 ...