通过maven引入,坐标如下:
<dependency>
<groupId>com.alibabagroupId>
<artifactId>easyexcel-coreartifactId>
<version>3.3.2version>
dependency>
下面以权限系统中的角色列表为案例,演示如何导出数据
实体类
import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.annotation.format.DateTimeFormat;
import com.alibaba.excel.annotation.write.style.*;
import com.alibaba.excel.enums.poi.HorizontalAlignmentEnum;
import com.alibaba.excel.enums.poi.VerticalAlignmentEnum;
import lombok.Data;
import java.time.LocalDateTime;
/**
* 角色excel
*
* @author ez4sterben
* @date 2023/07/17
*/
@ContentRowHeight(30)
@HeadRowHeight(20)
@ColumnWidth(25)
@ContentStyle(horizontalAlignment = HorizontalAlignmentEnum.CENTER, verticalAlignment = VerticalAlignmentEnum.CENTER)
@Data
public class RoleExcelVO {
/**
* 角色名称
*/
@ExcelProperty(value = "角色名称")
private String roleName;
/**
* 权限字符
*/
@ExcelProperty(value = "权限字符")
private String permission;
/**
* 角色状态(0停用,1正常)
*/
@ExcelProperty(value = "角色状态")
private String status;
/**
* 备注
*/
@ExcelProperty(value = "备注")
private String remark;
/**
* 创建时间
*/
@DateTimeFormat("yyyy年MM月dd日HH时mm分ss秒")
@ExcelProperty(value = "创建时间")
private LocalDateTime createTime;
}
工具类
通过@Component把工具类交给spring管理,在需要使用的地方使用@Resource注入即可
将泛型设置为 " ? ",来表示任意类型,可以通过这一个方法完成所有类的相似导出操作,如果要投入使用的话可以对arrayList和excelVO的类型是否相同进行判断,这里没有进行判断。
import com.alibaba.excel.EasyExcel;
import org.springframework.stereotype.Component;
import java.util.ArrayList;
/**
* 简单excel工具类
*
* @author ez4sterben
* @date 2023/07/17
*/
@Component
public class EasyExcelUtil {
public static final String XLSX = ".xlsx";
public String export(ArrayList<?> arrayList, Class<?> excelVO, String sheetName) {
String fileName = System.currentTimeMillis() + XLSX;
EasyExcel.write(fileName, excelVO).sheet(sheetName).doWrite(arrayList);
return fileName;
}
}
业务层
@Resource
private EasyExcelUtil easyExcelUtil;
public static final String SHEET_NAME = "角色表";
/**
* 导出
*
* @param ids id
* @return {@link String}
* @throws IOException ioexception
*/
@Override
public String export(List<Long> ids) throws IOException {
// 前端传参ids,查询数据
List<RolePO> rolePOS = this.listByIds(ids);
ArrayList<RoleExcelVO> roleExcelVOS = new ArrayList<>();
rolePOS.forEach(rolePO -> {
// 通过hutool的BeanUtils把内容抄送给roleExcelVO
RoleExcelVO roleExcelVO = new RoleExcelVO();
BeanUtils.copyProperties(rolePO,roleExcelVO);
roleExcelVOS.add(roleExcelVO);
});
return easyExcelUtil.export(roleExcelVOS,RoleExcelVO.class,SHEET_NAME);
}
由于我们刚才已经封装过工具类,那么这里不限于角色表的导出,还可以是其他的任何表,比如我要导出用户表,那么我只需要扒这部分代码写入用户的业务层就可以
Controller层
/**
* 导出
*
* @return {@link Result}<{@link List}<{@link BusinessVO}>>
*/
@PostMapping("/export")
public void export(@RequestBody List<Long> ids, HttpServletResponse response) throws IOException {
String filePath = roleService.export(ids);
try {
//输入流,通过输入流将读取文件内容
FileInputStream fileInputStream = new FileInputStream(filePath);
//输出流,通过输出流将文件回写到浏览器,在浏览器展示图片
ServletOutputStream outputStream = response.getOutputStream();
response.setContentType("application/vnd.ms-excel");
response.setHeader("Content-Disposition", "attachment; filename=角色表.xlsx");
response.setStatus(200);
int len = 0;
byte[] bytes = new byte[1024];
while ((len = fileInputStream.read(bytes)) > 0) {
outputStream.write(bytes, 0, len);
}
outputStream.flush();
//关闭流
fileInputStream.close();
outputStream.close();
// 返回成功后删除文件
new File(filePath).delete();
} catch (Exception e) {
e.printStackTrace();
}
}
VUE调用
// 导出
handleExport() {
axios({
method: "post",
data: this.selectedRoles, // 这里写ids []
url: this.urls.export, // 这里写你自己的后端url
responseType: "blob"
}).then((res) => {
const blob = new Blob([res.data]);
const a = document.createElement("a");
const href = window.URL.createObjectURL(blob);
a.href = href;
a.download = '角色表权限.xlsx';
document.body.appendChild(a);
a.click();
document.body.removeChild(a);
window.URL.revokeObjectURL(href);
}).catch((error) => {});
},
下载通过blob实现,博主前端写的不规范,请自行更改。
data和url和你自己的后端对应上即可。
结果展示