使用Java结合Apache POI可实现员工信息批量导入导出,通过Maven引入poi-ooxml依赖处理Excel文件;2. 定义Employee类封装姓名、年龄、部门和邮箱信息;3. 导出时创建XSSFWorkbook,写入表头和员工数据并保存为Excel文件;4. 导入时读取XSSFWorkbook中首张工作表,跳过表头逐行解析单元格并封装为Employee对象列表返回;5. 实际应用需增强异常处理与数据校验以提升健壮性。

在企业管理系统中,员工信息的批量导入导出是常见需求。使用Java可以结合Apache POI等库高效实现Excel文件的读写操作。下面介绍如何用Java完成这一功能。
1. 引入Apache POI依赖
Apache POI是处理Microsoft Office文档的强大工具,支持读写Excel文件。在Maven项目中添加以下依赖:
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>5.2.3</version>
</dependency>
该依赖包含处理.xlsx格式所需的所有组件。
2. 定义员工实体类
创建Employee类用于封装员工信息:
立即学习“Java免费学习笔记(深入)”;
public class Employee {
private String name;
private int age;
private String department;
private String email;
// 构造方法、getter和setter省略
}
3. 实现Excel数据导出
将员工列表写入Excel文件:
public void exportEmployees(List<Employee> employees, String filePath) throws IOException {
Workbook workbook = new XSSFWorkbook();
Sheet sheet = workbook.createSheet("员工信息");
Row headerRow = sheet.createRow(0);
headerRow.createCell(0).setCellValue("姓名");
headerRow.createCell(1).setCellValue("年龄");
headerRow.createCell(2).setCellValue("部门");
headerRow.createCell(3).setCellValue("邮箱");
int rowNum = 1;
for (Employee e : employees) {
Row row = sheet.createRow(rowNum++);
row.createCell(0).setCellValue(e.getName());
row.createCell(1).setCellValue(e.getAge());
row.createCell(2).setCellValue(e.getDepartment());
row.createCell(3).setCellValue(e.getEmail());
}
try (FileOutputStream out = new FileOutputStream(filePath)) {
workbook.write(out);
}
workbook.close();
}
4. 实现Excel数据导入
从Excel文件读取数据并转换为员工对象列表:
public List<Employee> importEmployees(String filePath) throws IOException {
List<Employee> employees = new ArrayList<>();
Workbook workbook = new XSSFWorkbook(new FileInputStream(filePath));
Sheet sheet = workbook.getSheetAt(0);
boolean isHeader = true;
for (Row row : sheet) {
if (isHeader) {
isHeader = false;
continue;
}
Employee e = new Employee();
e.setName(row.getCell(0).getStringCellValue());
e.setAge((int) row.getCell(1).getNumericCellValue());
e.setDepartment(row.getCell(2).getStringCellValue());
e.setEmail(row.getCell(3).getStringCellValue());
employees.add(e);
}
workbook.close();
return employees;
}
注意:实际应用中需增加异常处理,如空值判断、数据类型校验、文件格式验证等,确保程序健壮性。
基本上就这些。掌握POI的基本API后,可以根据实际模板调整列顺序或支持更多字段。导入导出功能对提升系统数据迁移效率很有帮助。
以上就是如何使用Java实现员工信息批量导入导出的详细内容,更多请关注php中文网其它相关文章!