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层的,您需要封装多少列,每列的标题以及数据,改变这些代码,以及您的数据来源,其他的基本就不用动了。祝您早日完成工作。