easypoi导入校验跳过空行_EasyPoi导入验证功能

这篇博客介绍了如何使用EasyPoi库在Java中实现Excel导入功能,并在导入过程中进行数据校验。通过设置ImportParams对象,启用验证支持并自定义验证处理器,实现了对Excel数据的有效性检查。当数据验证失败时,博客展示了如何获取错误数据并将其导出为新的Excel文件供用户下载。
摘要由CSDN通过智能技术生成

@Controller

@RequestMapping("/import")

public class ImportController extends BaseController {

@Autowired

private IEmployeeService employeeService;

@Autowired

private IDepartmentService departmentService;

@Autowired

private EmployeeExcelVerifyHandler employeeExcelVerifyHandler;

@RequestMapping("/index")

public String index(){

return "import";

}

@RequestMapping("/employeeXlsx")

public String employeeXlsx(MultipartFile empFile, HttpServletResponse response) throws Exception {

//一.使用EasyPoi获取文件数据

ImportParams params = new ImportParams();

params.setHeadRows(1);

params.setNeedVerfiy(true); //设置验证支持

params.setVerifyHandler(employeeExcelVerifyHandler); //设置一个验证处理器

//二.获取excel中的数据,封装成了一个结果对象(有很多东西)

ExcelImportResult result = ExcelImportUtil.importExcelMore(

empFile.getInputStream(),

Employee.class, params);

//三.获到正确的数据,并把它们保存到数据库

List list = result.getList();

list.forEach(e->{

e.setPassword("123");

Department dept = departmentService.findByName(e.getDepartment().getName());

e.setDepartment(dept);

employeeService.save(e);

});

//四.如果有错误,把错误数据返回到前台(让前台下载一个错误的excel)

//4.1判断是否有错误

if(result.isVerfiyFail()){

//4.2拿到错误的文件薄

Workbook failWorkbook = result.getFailWorkbook();

//把这个文件导出

response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"); //mime类型

response.setHeader("Content-disposition", "attachment;filename=error.xlsx"); //告诉浏览下载的是一个附件,名字叫做error.xlsx

response.setHeader("Pragma", "No-cache");//设置不要缓存

OutputStream ouputStream = response.getOutputStream();

failWorkbook.write(ouputStream);

ouputStream.flush();

ouputStream.close();

}

return "import";

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值