Java使用EasyExcel导入导出数据表

添加依赖

        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <version>3.2.1</version>
        </dependency>

导入,操作数据库的逻辑根据自己的业务修改

public class PersonListener extends AnalysisEventListener {

    List<PersonDO> personList = new ArrayList<>();

    @Override
    public void invoke(Object o, AnalysisContext analysisContext) {
        PersonDO personDO = new PersonDO();
        String devNo = ((PersonDO) o).getDevNo();
        personDO.setDevNo(devNo);
        String empName = ((PersonDO) o).getEmpName();
        personDO.setEmpName(empName);
        String empNo = ((PersonDO) o).getEmpNo();
        personDO.setEmpNo(empNo);
        String depName = ((PersonDO) o).getDepName();
        personDO.setDepName(depName);

        personList.add(personDO);
    }

    @Override
    public void onException(Exception exception, AnalysisContext context) throws Exception {
        super.onException(exception, context);
    }

    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {
        personList.clear();
    }
}
@RestController
@RequestMapping("/import/")
public class PersonImport {
    private final DeviceMapper deviceMapper;
    private final EmployeeMapper employeeMapper;

    private final DepMapper depMapper;

    public PersonImport(DepMapper depMapper, EmployeeMapper employeeMapper, DeviceMapper deviceMapper) {
        this.depMapper = depMapper;
        this.employeeMapper = employeeMapper;
        this.deviceMapper = deviceMapper;
    }

    @PostMapping("person")
    public CommonResult importExcel(MultipartFile file) {
        try {
            //获取文件的输入流
            InputStream inputStream = file.getInputStream();
            List<PersonDO> lst = EasyExcel.read(inputStream) //调用read方法
                                          //注册自定义监听器,字段校验可以在监听器内实现
                                          .registerReadListener(new PersonListener())
                                          .head(PersonDO.class) //对应导入的实体类
                                          .sheet(0) //导入数据的sheet页编号,0代表第一个sheet页,如果不填,则会导入所有sheet页的数据
                                          .headRowNumber(1) //列表头行数,1代表列表头有1行,第二行开始为数据行
                                          .doReadSync(); //开始读Excel,返回一个List<T>集合,继续后续入库操作

            //导入数据库操作
            for (PersonDO personDO : lst) {
                Optional<PersonDO> optionalPersonDO = Optional.ofNullable(personDO);
                EmployeeDTO employeeDTO = new EmployeeDTO();
                DeviceDTO deviceDTO = new DeviceDTO();
                //  判断是否存在该单位
                optionalPersonDO.map(PersonDO::getDepName).ifPresent(name -> {
                    Department depByName = depMapper.getDepByName(name);
                    if (ObjectUtils.isEmpty(depByName)) {
                        throw new CommonException(YIXGResultEnum.DEP_NOT_EXIST.getCode(),
                                YIXGResultEnum.DEP_NOT_EXIST.getMessage());
                    }
                    employeeDTO.setEmpDepID(depByName.getDepID());
                    deviceDTO.setDevDepID(depByName.getDepID());
                });
                //  判断人员编号是否重复
                optionalPersonDO.map(PersonDO::getEmpNo).ifPresent(no -> {
                    Employee empByNo = employeeMapper.getEmpByNo(null, no);
                    if (!ObjectUtils.isEmpty(empByNo)) {
                        throw new CommonException(YIXGResultEnum.EMPNO_CANNOT_REPEAT.getCode(),
                                YIXGResultEnum.EMPNO_CANNOT_REPEAT.getMessage());
                    }
                    employeeDTO.setEmpNo(no);
                    optionalPersonDO.map(PersonDO::getEmpName).ifPresent(name -> {
                        employeeDTO.setEmpName(name);
                        employeeDTO.setEmpCreateTime(new Date());
                        employeeDTO.setEmpEnable(true);
                        employeeMapper.addEmp(employeeDTO);
                        deviceDTO.setDevEmpID(employeeDTO.getEmpID());
                    });
                });
                //  判断设备编号是否重复
                optionalPersonDO.map(PersonDO::getDevNo).ifPresent(no -> {
                    Device devByNO = deviceMapper.getDevByNO(null, no);
                    if (!ObjectUtils.isEmpty(devByNO)) {
                        throw new CommonException(YIXGResultEnum.DEVICENO_CANNOT_REPEAT.getCode(),
                                YIXGResultEnum.DEVICENO_CANNOT_REPEAT.getMessage());
                    }
                    deviceDTO.setDevNo(no);
                    deviceDTO.setDevCreateTime(new Date());
                    deviceDTO.setDevEnable(true);
                    deviceMapper.addDev(deviceDTO);
                });
            }
            return new CommonResult().setCode(YIXGResultEnum.OPERATE_SUCCESS.getCode())
                                     .setMessage(YIXGResultEnum.OPERATE_SUCCESS.getMessage());
        } catch (IOException exception) {
            throw new RuntimeException(exception);
        }
    }
}

导出

@RestController
@RequestMapping("/export/")
public class PersonExport {
    private final EmployeeMapper employeeMapper;
    private final DeviceMapper deviceMapper;

    public PersonExport(DeviceMapper deviceMapper, EmployeeMapper employeeMapper) {
        this.deviceMapper = deviceMapper;
        this.employeeMapper = employeeMapper;
    }

    private void setExcelResponseProp(
            HttpServletResponse response, String rawFileName
    ) throws UnsupportedEncodingException {
        //  设置内容类型
        response.setContentType("application/vnd.vnd.ms-excel");
        //  设置编码格式
        response.setCharacterEncoding("UTF-8");
        //  设置导出文件名称
        String fileName = URLEncoder.encode(rawFileName.concat(".xlsx"), StandardCharsets.UTF_8);
        //  设置响应头
        response.setHeader("Content-disposition", "attachment;filename*=utf-8' '" + fileName + ".xlsx");
    }

    @GetMapping("person")
    public void exportPersonExcel(HttpServletResponse response) throws IOException {
        OutputStream outputStream = response.getOutputStream();
        try {
            this.setExcelResponseProp(response, "人员列表");
            // 模拟根据条件在数据库查询数据
            List<PersonDO> personList = new ArrayList<>();
            List<Employee> empList = employeeMapper.empListToAll(new EmployeeDTO());
            for (Employee employee : empList) {
                PersonDO personDO = new PersonDO();
                Optional<Employee> employeeOptional = Optional.ofNullable(employee);
                employeeOptional.map(Employee::getDevice).map(Device::getDevNo).ifPresent(personDO::setDevNo);
                employeeOptional.map(Employee::getEmpName).ifPresent(personDO::setEmpName);
                employeeOptional.map(Employee::getEmpNo).ifPresent(personDO::setEmpNo);
                employeeOptional.map(Employee::getDepartment).map(Department::getDepName).ifPresent(
                        personDO::setDepName);
                personList.add(personDO);
            }
            //这个实现方式非常简单直接,使用EasyExcel的write方法将查询到的数据进行处理,以流的形式写出即可
            EasyExcel.write(outputStream, PersonDO.class)//对应的导出实体类
                     .excelType(ExcelTypeEnum.XLSX)//excel文件类型,包括CSV、XLS、XLSX
                     .sheet("人员列表")//导出sheet页名称
                     .doWrite(personList); //查询获取的数据集合List<T>,转成excel
        } catch (IOException e) {
            throw new RuntimeException(e);
        } finally {
            outputStream.flush();
            outputStream.close();
        }
    }

    @GetMapping("device")
    public void exportDeviceExcel(HttpServletResponse response) throws IOException {
        OutputStream outputStream = response.getOutputStream();
        try {
            this.setExcelResponseProp(response, "设备列表");
            // 模拟根据条件在数据库查询数据
            List<PersonDO> devList = new ArrayList<>();
            List<Device> deviceList = deviceMapper.devListToAll(new DeviceDTO());
            for (Device device : deviceList) {
                PersonDO personDO = new PersonDO();
                Optional<Device> optionalDevice = Optional.ofNullable(device);
                optionalDevice.map(Device::getDevNo).ifPresent(personDO::setDevNo);
                optionalDevice.map(Device::getEmployee).map(Employee::getEmpName)
                              .ifPresent(personDO::setEmpName);
                optionalDevice.map(Device::getEmployee).map(Employee::getEmpNo).ifPresent(personDO::setEmpNo);
                optionalDevice.map(Device::getDepartment).map(Department::getDepName).ifPresent(
                        personDO::setDepName);
                devList.add(personDO);
            }
            //这个实现方式非常简单直接,使用EasyExcel的write方法将查询到的数据进行处理,以流的形式写出即可
            EasyExcel.write(outputStream, PersonDO.class)//对应的导出实体类
                     .excelType(ExcelTypeEnum.XLSX)//excel文件类型,包括CSV、XLS、XLSX
                     .sheet("设备列表")//导出sheet页名称
                     .doWrite(devList); //查询获取的数据集合List<T>,转成excel
        } catch (IOException e) {
            throw new RuntimeException(e);
        } finally {
            outputStream.flush();
            outputStream.close();
        }
    }
}

以下是使用 Java 实现 EasyExcel 导入导出的示例代码: 1. 引入 EasyExcel 依赖: ```xml <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>2.1.7</version> </dependency> ``` 2. 定义 Excel 数据模型: ```java public class User { @ExcelProperty("姓名") private String name; @ExcelProperty("年龄") private Integer age; // 省略 getter 和 setter 方法 } ``` 3. 编写 Excel 数据读取代码: ```java public void readExcel(File excelFile) { EasyExcel.read(excelFile, User.class, new AnalysisEventListener<User>() { @Override public void invoke(User user, AnalysisContext analysisContext) { // 处理读取到的数据 System.out.println(user); } @Override public void doAfterAllAnalysed(AnalysisContext analysisContext) { // 读取完毕后的操作 } }).sheet().doRead(); } ``` 4. 编写 Excel 数据写入代码: ```java public void writeExcel(File excelFile, List<User> userList) { EasyExcel.write(excelFile, User.class).sheet().doWrite(userList); } ``` 5. 配置 Excel 文件的格式: 可以使用注解或配置文件来设置 Excel 文件的格式,例如: ```java public class User { @ExcelProperty(value = "姓名", index = 0) private String name; @ExcelProperty(value = "年龄", index = 1) @ColumnWidth(15) private Integer age; // 省略 getter 和 setter 方法 } ``` 6. 执行导入导出操作: ```java File excelFile = new File("test.xlsx"); // 读取 Excel 文件 readExcel(excelFile); // 写入 Excel 文件 List<User> userList = new ArrayList<>(); userList.add(new User("张三", 20)); userList.add(new User("李四", 25)); writeExcel(excelFile, userList); ``` 总的来说,使用 EasyExcel 进行 Excel 文件的导入导出操作非常简单,只需要几行代码即可完成。同时,EasyExcel 还提供了丰富的 API,可以满足不同场景下的需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值