精华内容
下载资源
问答
  • 2021-01-25 10:08:59

    将数据库数据导出到Excel

    添加依赖

    <dependency>
        <groupId>org.apache.poi</groupId>
        <artifactId>poi</artifactId>
        <version>3.14</version>
    </dependency>
    <dependency>
        <groupId>org.apache.poi</groupId>
        <artifactId>poi-ooxml</artifactId>
        <version>3.14</version>
    </dependency>
    

    工具类

    import org.apache.poi.hssf.usermodel.HSSFRow;
    import org.apache.poi.hssf.usermodel.HSSFSheet;
    import org.apache.poi.hssf.usermodel.HSSFWorkbook;
    
    import java.lang.reflect.Field;
    import java.util.List;
    
    /**
     *  数据导出excel,工具类
     * */
    public class ExcelUtils {
    
        /**
         *  生成Excel表格
         * @param sheetName sheet名称
         * @param titleList 表头列表
         * @param dataList 数据列表
         * @return HSSFWorkbook对象
         * */
        public static HSSFWorkbook createExcel(String sheetName,
                                               List<String> titleList,List dataList) throws IllegalAccessException {
    
            //创建HSSFWorkbook对象
            HSSFWorkbook wb = new HSSFWorkbook();
            //创建sheet对象
            HSSFSheet sheet=wb.createSheet(sheetName);
            //在sheet里创建第一行,这里即是表头
            HSSFRow rowTitle=sheet.createRow(0);
    
            //写入表头的每一个列
            for (int i = 0; i < titleList.size(); i++) {
                //创建单元格
                rowTitle.createCell(i).setCellValue(titleList.get(i));
            }
    
            //写入每一行的记录
            for (int i = 0; i < dataList.size(); i++) {
                //创建新的一行,递增
                HSSFRow rowData = sheet.createRow(i+1);
    
                //通过反射,获取POJO对象
                Class cl = dataList.get(i).getClass();
                //获取类的所有字段
                Field[] fields = cl.getDeclaredFields();
                for (int j = 0; j < fields.length; j++) {
                    //设置字段可见,否则会报错,禁止访问
                    fields[j].setAccessible(true);
                    //创建单元格
                    rowData.createCell(j).setCellValue((String) fields[j].get(dataList.get(i)));
                }
            }
            return wb;
        }
    }
    

    实现数据Excel导出

     /**
       * 信息Excel导出
       * time是根据时间查询数据源的参数
       * @param
       * @return
       */
    @GetMapping("getOrderByTime")
    public Result getOrderByTime(HttpServletResponse response, @RequestParam(value = "time") String stoptime) {
    	try {
    		String fileName = "订单数据导出";
    		// sheet名
    		String sheetName = "sheet";
    		//表头集合,作为表头参数
    		List<String> titleList = new ArrayList<>();
    		titleList.add("日期");
    		titleList.add("订单数量(单)");
    		titleList.add("营业额(元)");
    		titleList.add("营业利润(元)");
    		
    		// resultList是根据参数time从数据库查出来的数据源(暂时用一个空集合代替)
    		List<Result> resultList = new ArrayList<>();
    		//TODO
    		
    		//调取封装的方法,传入相应的参数
    		HSSFWorkbook workbook = ExcelUtils.createExcel(sheetName, titleList, resultList );
    		//输出Excel文件
    		OutputStream output = response.getOutputStream();
    		response.reset();
    		//中文名称要进行编码处理
    		response.setHeader("Content-disposition", "attachment; filename=" + new String(fileName.getBytes("GB2312"), "ISO8859-1") + ".xls");
    		response.setContentType("application/x-xls");
    		workbook.write(output);
    		output.close();
    		return ResultUtil.success();
    		
    	} catch (Exception e) {
            e.printStackTrace();
            return ResultUtil.setERROR();
        }
    }
    

    调用

    http://172.16.17.235:9010/ahc/getOrderByTime?time=2021-01-20 13:22:17

    浏览器上访问地址后会自动下载一个Excel文件
    在这里插入图片描述
    在这里插入图片描述
    到这里Excel导出就完成了。

    更多相关内容
  • 今天需要写一个导出Excel的功能,但是发现当数据量到3万条时,列数在23列时,内存溢出,CPU使用100%,测试环境直接炸掉。小编给大家分享基于java使用POI导出数据Excel的方法,感兴趣的朋友一起看看吧
  • 该项目为Java web实现的数据导出Excel小案例,采用了POI进行处理。
  • 开发测试时候导入数据遇到大数据导入的问题,整理了下,需要的朋友可以参考下
  • 支持从数据库中查询到数据,以多级表头形式导入到Excel文件中。比如:一级表头:学号、姓名、各科成绩。二级表头:语文、数学、英语(二级表头在各科成绩下面)。
  • java poi导出大量数据Excel
  • Java导出数据Excel文件中,支持多页签形式,如通过Java导出一个名为“各部门人员列表”,然后在文件中有三个页签,分别为“研发部”、“综合部”、“财务部”。其中这三个页签里面的数据就是通过Java导出Excel...
  • 2、java读取数据库数据,并导出excel文件。 3、README.md中有详细的操作步骤示例。 使用说明: 1. 先使用postman导入:other/excel相关.postman_collection.json 2. 导入sql到数据库:other/excel.sql 3. idea导入...
  • 本实例可以多个不同对象集合或者一个对象集合的数据导出Excel表格中,能实现最大通用化。
  • 目前java框架中能够生成excel文件的的确不少,但是,能够生成大数据量的excel框架,我倒是没发现,一般数据量大了都会出现内存溢出,所以,生成大数据量的excel文件要返璞归真,用java的基础技术,IO流来实现。...
  • 主要为大家详细介绍了java导出大批量即百万以上数据excel文件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
  • 轻松解决普通poi形式导出Excel的中出现的栈溢出问题,此资源可实现千万级数据分批导出csv文件,csv大数据量导出(千万级别,不会内存溢出),多线程导出 ,生产环境已经很稳定的使用着
  • web项目中需要有将数据导出excel的操作需求 使用html格式导出方法,但在导出时,根据最大行数重新建立新的excel文件; 数据从数据库取出使用纯jdbc方式读数据,边读边向文件中写; 待所有数据写完,将各个小excel...
  • java实现excel导出功能

    2019-11-27 18:14:51
    java实现excel导出功能,通过查询数据库指定数据,将数据excel方式导出的功能 excel导出的功能
  • java使用POI导出 Excel+图片工具类 ,里面含有poi jar包,只调用接口即可直接保存Excel。使用的时候需先把数据封装,具体包装需根据实际导出数据进行处理。文件demo中只提供包装格式。
  • Java导出Excel表格

    2020-12-22 20:49:37
     Web开发是,我们经常会遇见客户要求,某些数据导出Excel,有利于客户分析和打印等等。下面是导出Excel下载的对应是JSP.  1.点击“导出”按钮时,触发exportExcel()的JS方法,JS方法跳到对应的JSP,实现导出...
  • 本文主要介绍了Java根据模板导出Excel报表并复制模板生成多个Sheet页的方法,具有很好的参考价值。下面跟着小编一起来看下吧
  • java项目史上最简单的数据excel导出教程(demo),无论是程序小白还是老手,都非常的友好
  • JAVA 百万数据 导出 EXCEL POI,支持 100W 200W 300w等无限量大数据导出,有兴趣的同学可以参考学习,有问题可以咨询QQ450591221
  • java实现导出Excel多行表头复杂模板 一般我们都会选择poi来导出,选择一个比较好的ExcelUtils 但是对于初学者而言不了解poi的,还需从poi API文档去学习,如果是自学的话更好,如果是公司安排的任务,没有接触过有...
  • jxl.jar是通过java操作excel表格的工具类库,是由java语言开发而成的。通过jxl可以把数据导入到excel。例子在另外一个资源里面
  • NULL 博文链接:https://wjsqiuqiu201305143544.iteye.com/blog/1870663
  • 下面小编就为大家带来一篇Java程序实现导出Excel的方法(支持IE低版本)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
  • 用开源 Apache POI 技术导出Excel,解决导出大数据出现OOM、栈溢出问题,此资源可实现百万级数据多线程分批导出Excel文件,不会内存溢出,生产环境已很稳定的使用者,所以用到的技术很核心、值得参考
  • 能够实现「导入/导出 Excel」的第三方常用类库有 Apache poi、Java Excel(JXL)和阿里巴巴开源的 Easyexcel 等。这么多类库该怎么选呢?在这里小编给大家推荐阿里巴巴开源的「Easyexcel」。 性能对比 poi 和 jxl ...
  • java中使用poi导出Excel大批量数据 存在两个导出方法:存在一个分批量导出ZIP文件,一个导出exel文件
  • java导出excel

    2017-10-31 15:46:05
    java从数据库导出数据excel表格,对用字段和相应列。
  • 主要介绍了Java导出excel时合并同一列中相同内容的行,需要的朋友可以参考下
  • java数据excel导出小Demo

    2021-05-07 15:36:34
    java数据excel导出小Demo
  • * 这是一个通用的方法,利用了JAVA的反射机制,可以将放置在JAVA集合中并且符号一定条件的数据EXCEL 的形式输出到指定IO设备上 * * @param title * 表格标题名 * @param headers * 表格属性列名数组 ...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 44,362
精华内容 17,744
关键字:

java把数据导出excel

java 订阅