如何批量导出数据到excel并下载,看这一篇就够了,一看就会

Excel在开发工作中比较常用的,最近做了一个功能就是批量导出数据到excel,并下载。今天上线了,特将代码贴出来,方便自己以后再做类似功能,能够更快上手,也方便更多没做过Excel功能的童鞋,更快的完成任务。各个层都包含的代码都有哦。
废话不多说
第一步 :导入解析excel需要的pom依赖

 <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>

第二步:编写controller层代码(根据各自编写各层顺序喜好调整)

@GetMapping("/excelExportWhiteList")
	public void batchExportWhiteList(HttpServletResponse response) throws IOException {
		//解决文件名中文乱码
		String fileName = "白名单用户信息表" ;
		OutputStream outputStream=null;
		Workbook wb=shySaleService.batchExportWhiteList();
		//这行代码是固定的,就是说要以excel格式的文件
		response.setContentType("application/vnd.ms-excel");
		//这一行代码也是大部分是固定的,告诉以附件的形式下载,就 
		
		response.setHeader("Content-disposition", "attachment;filename="+new String(fileName.getBytes("gb2312"),"iso-8859-1") + ".xlsx");
		outputStream=response.getOutputStream();
        //response.setHeader("Content-disposition","attachment;filename="+ URLEncoder.encode("白名单用户信息表.xlsx","utf-8"));
		outputStream=response.getOutputStream();
		wb.write(outputStream);
		outputStream.flush();
		outputStream.close();
		
	}

第三步 :编写service层代码

 @Override
    public Workbook  batchExportWhiteList() throws IOException {
        //查询出所有的白名单用户信息
        List<TabCommodityWhiteList> list=tabCommodityWhiteListMapper.queryWhiteList();
        if (CollectionUtils.isEmpty(list)) {
            throw new RuntimeException("白名单用户信息为空");
        }
            //创建workbook
            Workbook workbook = new XSSFWorkbook();
            //创建sheet
            Sheet sheet = workbook.createSheet("白名单用户信息表");
            //在sheet中添加表头第0行标题
            Row row1 = sheet.createRow(0);
            Cell ceLL11 = row1.createCell(0);
            ceLL11.setCellValue("用户名称");
            //第一行第二列标题
            Cell ceLL12 = row1.createCell(1);
            ceLL12.setCellValue("手机号码");
            //第三列标题
            Cell ceLL13 = row1.createCell(2);
            ceLL13.setCellValue("用户等级");
            //需要封装的数据的个数
            int length = list.size();
        System.out.println("白名单个数"+length);
            //开始封装数据,因为excel第一行写了标题,所以从1 //开始循环
            for (int i = 1; i < length; i++) {
                Row row = sheet.createRow(i );
                row.createCell(0).setCellValue(list.get(i).getUserName()==null? "":list.get(i).getUserName());
                row.createCell(1).setCellValue(list.get(i).getPhoneNo()==null? "":list.get(i).getPhoneNo());
                row.createCell(2).setCellValue(list.get(i).getUserLevel()== null? 100 :list.get(i).getUserLevel());

            }

            return  workbook;
    }

第四步:编写dao层代码,就是获得需要导出的数据,当然,可能你最后要导出的数据不是直接从数据库获得的原生数据,需要处理的数据,那你就自己处理。我这里导出的数据就是从数据库根据条件查出来的数据。

 /**
     * 查询全部白名单用户信息
     */
    List<TabCommodityWhiteList> queryWhiteList();

编写mapper.xml文件中的sql语句

<select id="queryWhiteList" resultMap="whiteListResultMap">
       select  id,
       commodity_id,
       user_id,
       user_name,
       phone_no,
       user_level,
       logic_delete,
       create_time,
       update_time,
       create_by,
       update_by
       from  tab_commodity_whitelist
       where logic_delete=0
    </select>

到这里,后端的事就全部搞定了。前端调用这个接口之后,就会在页面生成一个附件文件,以excel的形式存在,前端只要做简单的处理就能下载了。
说明:我这就是一个很标准的excel批量导出的代码,如果您看到了我的代码,各个层的返回值数据类型不用变动,您只需要改变service层的,您需要封装多少列,每列的标题以及数据,改变这些代码,以及您的数据来源,其他的基本就不用动了。祝您早日完成工作。

  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值