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

在《easypoi导入校验跳过空行》中,展示了如何使用EasyPoi处理Excel导入时的数据验证。通过创建ImportParams对象,设置头部行数和开启验证支持,再指定自定义的验证处理器,可以实现对导入数据的有效校验。如果验证失败,错误数据将被单独导出供用户查看。示例代码展示了如何整合这些功能并保存正确数据到数据库。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

@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、付费专栏及课程。

余额充值