EasyExcel 实践案例:打印工资条

文章目录

    • [🎯 1. 每个人一个 Excel 文件(单个对象填充)](#🎯 1. 每个人一个 Excel 文件(单个对象填充))
    • [🎯 2. 每个人一个 Sheet(批量生成工资单)](#🎯 2. 每个人一个 Sheet(批量生成工资单))
    • [🎯 3. 一张工资表,多个员工(列表数据填充)](#🎯 3. 一张工资表,多个员工(列表数据填充))
    • [📌 总结](#📌 总结)
      • [✅ 最佳实践](#✅ 最佳实践)

打印工资条时,每个人的工资条是 一个独立的 Sheet一个独立的 Excel 文件,具体占位符用法取决于你如何填充数据:


🎯 1. 每个人一个 Excel 文件(单个对象填充)

适用于 :给每个员工生成 单独的 Excel 文件 ,比如 工资单.pdf、工资单.xlsx 等。

占位符格式{字段名}(不用加 .

📌 Excel 模板

员工姓名 工资 奖金
{name} {salary} {bonus}

📌 Java 代码

java 复制代码
List<Employee> employees = List.of(
    new Employee("张三", 10000, 2000),
    new Employee("李四", 12000, 2500)
);

for (Employee emp : employees) {
    String fileName = emp.getName() + "_工资单.xlsx";
    
    Map<String, Object> data = new HashMap<>();
    data.put("name", emp.getName());
    data.put("salary", emp.getSalary());
    data.put("bonus", emp.getBonus());

    ExcelWriter excelWriter = EasyExcel.write(fileName).withTemplate("salary_template.xlsx").build();
    WriteSheet writeSheet = EasyExcel.writerSheet().build();
    excelWriter.fill(data, writeSheet);
    excelWriter.finish();
}

这里用 {name},因为 data.put("name", "张三") 是一个 Map


🎯 2. 每个人一个 Sheet(批量生成工资单)

适用于 :一个 Excel 文件,每个员工一个 Sheet,比如 "2024年1月工资.xlsx"。

占位符格式{字段名}(不用加 .

📌 Java 代码

java 复制代码
String fileName = "2024年1月工资.xlsx";
List<Employee> employees = List.of(
    new Employee("张三", 10000, 2000),
    new Employee("李四", 12000, 2500)
);

ExcelWriter excelWriter = EasyExcel.write(fileName).withTemplate("salary_template.xlsx").build();

for (Employee emp : employees) {
    Map<String, Object> data = new HashMap<>();
    data.put("name", emp.getName());
    data.put("salary", emp.getSalary());
    data.put("bonus", emp.getBonus());

    WriteSheet writeSheet = EasyExcel.writerSheet(emp.getName() + "的工资单").build();
    excelWriter.fill(data, writeSheet);
}

excelWriter.finish();

这里 writeSheet() 指定了不同的 Sheet 名,每个人都有一个单独的工资单。


🎯 3. 一张工资表,多个员工(列表数据填充)

适用于 :在 同一个 Sheet 里显示多个员工工资信息(类似公司 HR 用的总表)。

占位符格式{.字段}(加 .

📌 Excel 模板

姓名 工资 奖金
{.name} {.salary} {.bonus}

📌 Java 代码

java 复制代码
String fileName = "工资表.xlsx";
List<Employee> employees = List.of(
    new Employee("张三", 10000, 2000),
    new Employee("李四", 12000, 2500)
);

ExcelWriter excelWriter = EasyExcel.write(fileName).withTemplate("salary_template.xlsx").build();
WriteSheet writeSheet = EasyExcel.writerSheet().build();
excelWriter.fill(employees, writeSheet);
excelWriter.finish();

这里用 {.name},因为 fill() 传的是 List<Employee>,EasyExcel 需要用 . 来解析列表数据。


📌 总结

场景 占位符格式 填充方式
每个人一个 Excel 文件 {字段}(无 . fill(Map)
每个人一个 Sheet {字段}(无 . fill(Map)
一个 Sheet,多个员工 {.字段}(有 . fill(List<T>)

✅ 最佳实践

  • 单个对象填充 (一个人一张工资单) 👉 用 {字段}(无 .
  • 列表数据填充 (工资表) 👉 用 {.字段}(有 .

这样,你就能正确地生成工资单啦!🚀

知识不扎实的可以回顾一下哦: EasyExcel 使用指南

相关推荐
老毛肚1 分钟前
手写mybatis
java·数据库·mybatis
两点王爷4 分钟前
Java基础面试题——【Java语言特性】
java·开发语言
choke2337 分钟前
[特殊字符] Python 文件与路径操作
java·前端·javascript
choke23312 分钟前
Python 基础语法精讲:数据类型、运算符与输入输出
java·linux·服务器
岁岁种桃花儿24 分钟前
CentOS7 彻底卸载所有JDK/JRE + 重新安装JDK8(实操完整版,解决kafka/jps报错)
java·开发语言·kafka
roman_日积跬步-终至千里1 小时前
【Java并发】Java 线程池实战:警惕使用CompletableFuture.supplyAsync
java·开发语言·网络
毕设源码-钟学长1 小时前
【开题答辩全过程】以 基于Springboot的扶贫众筹平台为例,包含答辩的问题和答案
java·spring boot·后端
CodeSheep程序羊1 小时前
拼多多春节加班工资曝光,没几个敢给这个数的。
java·c语言·开发语言·c++·python·程序人生·职场和发展
我是咸鱼不闲呀2 小时前
力扣Hot100系列19(Java)——[动态规划]总结(上)(爬楼梯,杨辉三角,打家劫舍,完全平方数,零钱兑换)
java·leetcode·动态规划
加油,小猿猿2 小时前
Java开发日志-双数据库事务问题
java·开发语言·数据库