poi和easypoi

在项目中想要操作office软件

导入poi的jar包

<!-- poi支持的jar包 -->
<dependency>
  <groupId>org.apache.poi</groupId>
  <artifactId>poi</artifactId>
  <version>3.11</version>
</dependency>
<dependency>
  <groupId>org.apache.poi</groupId>
  <artifactId>poi-ooxml</artifactId>
  <version>3.11</version>
</dependency>

在domain类中字段添加注解@Excel
例如:

@ExcelTarget("emp")
public class EasyEmployee extends BaseDomain{
    @Excel(name = "员工姓名")
    private String name;
    @Excel(name="邮件",width = 20)
    private String email;
    //性别
    @Excel(name="性别",replace={"男_true","女_false"})
    private boolean sex;
    @Excel(name="年纪")
    private Integer age;
    //出生日期
    @Excel(name="生日",format = "yyyy-MM-dd")
    private Date birthday;
    @ExcelEntity
    private EasyDept dept;
    @Excel(name="头像",type = 2)
    private String headImage;
    setget....
}

调用工具方法实现导入导出

//导入
List<EasyEmployee> easyEmployees = ExcelImportUtil.importExcel(file, EasyEmployee.class, importParams);
//导出方法
 Workbook workbook = ExcelExportUtil.exportExcel(new ExportParams(), EasyDept.class,
                list);

easypoi的认识使用

就算我们不会底层的POI,也可以非常轻松的完成Excel的操作。
虽然目前不够完善,但比较够用了。
注意导入easypoi的jar包可能会与原生的poi的jar包冲突。
先删除原生包,

<!-- easypoi的支持 -->
<dependency>
  <groupId>cn.afterturn</groupId>
  <artifactId>easypoi-base</artifactId>
  <version>3.2.0</version>
</dependency>
<dependency>
  <groupId>cn.afterturn</groupId>
  <artifactId>easypoi-web</artifactId>

首先完成导出功能

1.在页面添加导出按钮
2.点击发送请求到controller层
3.完成导出功能的实现
a)查询导出数据

b)处理图片

c)设置导出参数

d)导出视图处理

e)扫描视图的包

<context:component-scan base-package="cn.afterturn.easypoi.view" />
<bean id="beanNameViewResolver" class="org.springframework.web.servlet.view.BeanNameViewResolver"      p:order="0" />
//下载方法 download
@RequestMapping("/download")
//参1:前台传输的username passsword 需要高级查询不分页方法 findByQuery
//参2:模型ModelMap
//参3:req图片保存路径
public String download(EmployeeQuery employeeQuery, ModelMap map, HttpServletRequest req){
    //根据查询 查询数据
    List<Employee> employees = employeeService.findByQuery(employeeQuery);
    String realPath = req.getServletContext().getRealPath("");//E:\JavaEEIdeacode\aisell\src\main\web/images/head/avatar1.jpg
    employees.forEach(e->{
        //E:\JavaEEIdeacode\aisell\out\artifacts\aisell_Web_exploded\images\head
        e.setHeadImage(realPath+e.getHeadImage());
        System.out.println(e.getHeadImage());
    });
    //导出参数设置
    //E:\JavaEEIdeacode\aisell\src\main\web\images\head\sss.jpg
    ExportParams params = new ExportParams("员工数据", "员工表格1", ExcelType.XSSF);
    //固定两列的意思
    params.setFreezeCol(2);
    map.put(NormalExcelConstants.DATA_LIST, employees); // 数据集合
    map.put(NormalExcelConstants.CLASS, Employee.class);//导出实体
    map.put(NormalExcelConstants.PARAMS, params);//参数
    map.put(NormalExcelConstants.FILE_NAME, "xxx");//文件名称
    return NormalExcelConstants.EASYPOI_EXCEL_VIEW;//View名称


}

导入功能的实现

(1)新增页面import.jsp页面

​ 准备form表单,form表单里面提供一个上传的文件组件 easyui-filebox

<form action="/import/employeeXlsx" method="post" enctype="multipart/form-data">
    <input class="easyui-filebox" name="empFile" style="width:80%"
           data-options="prompt:'选择一个文件...',buttonText: '选择文件'" />
    <button class="easyui-linkbutton">导入</button>
</form>

2)点击导入 提交到后台进行导入处理

a)设置导入参数 --开启验证功能 开启自定义验证

​ 写一个类 去实现 接口

@Component
public class EmployeeExcelVerifyHandler implements IExcelVerifyHandler<Employee> {
    @Autowired
    private IEmployeeService employeeService;
    @Override
    public ExcelVerifyHandlerResult verifyHandler(Employee employee) {
        ExcelVerifyHandlerResult result = new ExcelVerifyHandlerResult(true);
        //检查用户名是否重复的方法
        boolean flag = employeeService.checkUsername(employee.getUsername());
        //检查用户名如果重复
        if(!flag){
            result.setSuccess(false);
            result.setMsg("用户名重复");
        }
        return result;
    }
}

注意 扫描的包

<context:component-scan base-package="cn.itsource.aisell.common"/>
//开启验证 -- 是否为null 最大值
        importParams.setNeedVerfiy(true);
        //加入自定义验证类 --验证用户名是否重复
        importParams.setVerifyHandler(employeeExcelVerifyHandler);

b)调用方法进行导入

 ExcelImportResult<Employee> result = ExcelImportUtil.importExcelMore(empFile.getInputStream(),
                Employee.class, importParams);

c)对于成功的结果 存入数据库

对于失败的结果 导出到前台展示

@RequestMapping("/employeeXlsx")
    public String employeeXlsx(MultipartFile empFile, HttpServletResponse response) throws Exception {
        ImportParams importParams = new ImportParams();
        importParams.setTitleRows(1);
        //开启验证 -- 是否为null 最大值
        importParams.setNeedVerfiy(true);
        //加入自定义验证类 --验证用户名是否重复
        importParams.setVerifyHandler(employeeExcelVerifyHandler);

        //完成导入 --调用导入
    /*    List<Employee> employees = ExcelImportUtil.importExcel(empFile.getInputStream(),
                Employee.class, importParams);*/
        //导入并且验证功能
        ExcelImportResult<Employee> result = ExcelImportUtil.importExcelMore(empFile.getInputStream(),
                Employee.class, importParams);

        result.getFailList().forEach(e->{
            System.out.println("失败数据:"+e);
        });
        //导入的数据 保存数据库
        result.getList().forEach(e->{
            System.out.println(e);
            //初始密码
            e.setPassword("123456");
            //根据部门名称 查询部门的id
            Department dept = departmentService.findByName(e.getDepartment().getName());
            e.setDepartment(dept);
            //存入数据库
            employeeService.save(e);
        });

        //把验证失败两个数据 导出到前台 error.xlsx
        if(result.isVerfiyFail()){
            //如果验证失败,代码到这里面来
            //失败的文件已经准备好了
            Workbook failWorkbook = result.getFailWorkbook();
            //把这个文件导出
            response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"); //mime类型
            response.setHeader("Content-disposition", "attachment;filename=error.xlsx");
            response.setHeader("Pragma", "No-cache");//设置不要缓存
            OutputStream ouputStream = response.getOutputStream();
            failWorkbook.write(ouputStream);
            ouputStream.flush();
            ouputStream.close();
        }

        return "import";
    }

验证功能

普通验证
导包

<!-- JSR 303 规范验证包 -->
<dependency>
  <groupId>org.hibernate</groupId>
  <artifactId>hibernate-validator</artifactId>
  <version>5.2.4.Final</version>
</dependency>

加上例如下面的@NotNull,@Max注解验证

@Excel(name="用户名")
    @NotNull(message = "用户名不能为空")
    private String username;
    private String password;

    @Excel(name="邮件")
    private String email;
    @Excel(name="年纪")
    @Max(value = 80,message = "年龄不能超过80")
    private Integer age;

自定义验证

@Component
public class EmployeeExcelVerifyHandler implements IExcelVerifyHandler<Employee> {

    @Autowired
    private IEmployeeService employeeService;

    @Override
    public ExcelVerifyHandlerResult verifyHandler(Employee employee) {
        ExcelVerifyHandlerResult result = new ExcelVerifyHandlerResult(true);
        //检查用户名是否重复的方法
        boolean flag = employeeService.checkUsername(employee.getUsername());
        //检查用户名如果重复
        if(!flag){
            result.setSuccess(false);
            result.setMsg("用户名重复");
        }
        return result;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值