EasyExcel 實踐案例:打印工資條

文章目錄

    • 💡 1. 每個員工一個 Excel 文件
      • ? 占位符格式
      • 📌 Excel 模板
      • 📌 Java 代碼
      • 🔥 關鍵點
    • 💡 2. 每個員工一個 Sheet
      • ? 占位符格式
      • 📌 Java 代碼
      • 🔥 關鍵點
    • 💡 3. 一個 Sheet,多個員工
      • ? 占位符格式
      • 📌 Excel 模板
      • 📌 Java 代碼
      • 🔥 關鍵點
    • 📌 總結
    • 🚀 最佳實踐

在實際開發中,我們經常需要使用 Excel 生成工資條,EasyExcel 提供了 模板填充 功能,使得批量生成工資單變得非常高效。本篇文章將詳細講解 三種常見工資單生成方式,并分析 占位符的正確使用方法


💡 1. 每個員工一個 Excel 文件

適用場景:每個員工的工資單是 獨立的 Excel 文件,適用于企業給員工發送工資單的情況。

? 占位符格式

  • 使用 {字段名}(不帶 .
  • 每個員工的數據 存儲在 Map<String, Object>

📌 Excel 模板

員工姓名工資獎金
{name}{salary}{bonus}

📌 Java 代碼

import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.write.metadata.WriteSheet;
import java.util.*;public class SalarySheetGenerator {public static void main(String[] args) {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());// 使用 EasyExcel 生成工資單EasyExcel.write(fileName).withTemplate("salary_template.xlsx").sheet().doFill(data);}}
}

🔥 關鍵點

? 占位符 {name}{salary}{bonus} 直接填充,因為 dataMap<String, Object>
? 每個員工單獨生成一個 Excel 文件


💡 2. 每個員工一個 Sheet

適用場景:一個 Excel 文件中,每個員工 單獨一個 Sheet,適用于 HR 統一管理工資單。

? 占位符格式

  • 使用 {字段名}(不帶 .
  • 每個員工的數據 存儲在 Map<String, Object>

📌 Java 代碼

import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.write.metadata.WriteSheet;
import java.util.*;public class SalarySheetGenerator {public static void main(String[] args) {String fileName = "2024年1月工資.xlsx";List<Employee> employees = List.of(new Employee("張三", 10000, 2000),new Employee("李四", 12000, 2500));// 創建 ExcelWriterExcelWriter 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();}
}

🔥 關鍵點

? 每個員工的數據單獨放入不同的 Sheet
? writeSheet(emp.getName() + "的工資單") 指定 Sheet 名稱
? 數據填充方式與單個 Excel 文件相同,仍然使用 {字段}


💡 3. 一個 Sheet,多個員工

適用場景所有員工的工資條放在同一個 Sheet,適用于企業 HR 統計所有員工工資情況

? 占位符格式

  • 使用 {.字段}(帶 .
  • 直接填充 List<Employee>

📌 Excel 模板

姓名工資獎金
{.name}{.salary}{.bonus}

📌 Java 代碼

import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.write.metadata.WriteSheet;
import java.util.*;public class SalarySheetGenerator {public static void main(String[] args) {String fileName = "工資表.xlsx";List<Employee> employees = List.of(new Employee("張三", 10000, 2000),new Employee("李四", 12000, 2500));// 生成 ExcelEasyExcel.write(fileName).withTemplate("salary_template.xlsx").sheet().doFill(employees);}
}

🔥 關鍵點

? 列表填充時,EasyExcel 需要使用 {.字段} 格式
? fill(List<Employee>) 讓 EasyExcel 自動匹配字段
? 所有員工工資信息都放在同一個 Sheet


📌 總結

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

🚀 最佳實踐

? 單個對象填充(一個人一張工資單) 👉 用 {字段}(無 .
? 列表數據填充(工資表) 👉 用 {.字段}(有 .

🔗 推薦閱讀:EasyExcel 使用指南

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/70844.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/70844.shtml
英文地址,請注明出處:http://en.pswp.cn/web/70844.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

編程題-從前序與中序遍歷序列構造二叉樹(中等-重點)

題目&#xff1a; 給定兩個整數數組 preorder 和 inorder &#xff0c;其中 preorder 是二叉樹的先序遍歷&#xff0c; inorder 是同一棵樹的中序遍歷&#xff0c;請構造二叉樹并返回其根節點。 提示: preorder 和 inorder 均 無重復 元素 解法一&#xff08;遞歸&#xff0…

Vue 3 + Vite 項目配置訪問地址到服務器某個文件夾的解決方案

前言 在開發 Vue 3 Vite 項目時&#xff0c;我們經常需要將項目部署到服務器的某個特定文件夾下。例如&#xff0c;將項目部署到 /my-folder/ 目錄下&#xff0c;而不是服務器的根目錄。這時&#xff0c;我們需要對 Vite 和 Vue Router 進行一些配置&#xff0c;以確保項目能…

【Rust中級教程】2.10. API設計原則之受約束性(constrained) Pt.1:對類型進行修改、`#[non_exhaustive]`注解

喜歡的話別忘了點贊、收藏加關注哦&#xff08;加關注即可閱讀全文&#xff09;&#xff0c;對接下來的教程有興趣的可以關注專欄。謝謝喵&#xff01;(&#xff65;ω&#xff65;) 2.10.1. 接口的更改要三思 如果你的接口要做出對用戶可見的更改&#xff0c;那么一定要三思…

Imagination GPU 3D Graphics Wrokload

本次分享Imagination GPU 的3D 圖像處理負載流程。 總的分為兩個階段 第一階段&#xff1a;Geometry Processing Phase&#xff08;幾何處理階段&#xff09;是渲染管線中的一個關鍵環節&#xff0c;主要負責對三維幾何數據進行處理和變換&#xff0c;以便后續在屏幕上進行顯…

自動化設備對接MES系統找DeepSeek問方案

項目需要現場的PLC設備HTTP協議JSON格式的方式對接MES系統平臺&#xff0c;于是試了一下&#xff1a; 找到的相關資源鏈接在這里。

VoIP之音頻3A技術

音頻3A技術是改善語音通話質量的三種關鍵技術的簡稱&#xff0c;包括聲學回聲消除&#xff08;Acoustic Echo Cancellation, AEC&#xff09;、自動增益控制&#xff08;Automatic Gain Control, AGC&#xff09;、自噪聲抑制&#xff08;Automatic Noise Suppression, ANS&…

量子計算的數學基礎:復數、矩陣和線性代數

量子計算是基于量子力學原理的一種新型計算模式,它與經典計算機在信息處理的方式上有著根本性的區別。在量子計算中,信息的最小單位是量子比特(qubit),而不是傳統計算中的比特。量子比特的狀態是通過量子力學中的數學工具來描述的,因此,理解量子計算的數學基礎對于深入學…

京準電鐘:NTP精密時鐘服務器在自動化系統中的作用

京準電鐘&#xff1a;NTP精密時鐘服務器在自動化系統中的作用 京準電鐘&#xff1a;NTP精密時鐘服務器在自動化系統中的作用 NTP精密時鐘服務器在自動化系統中的作用非常重要&#xff0c;特別是在需要高精度時間同步的場景中。NTP能夠提供毫秒級的時間同步精度&#xff0c;這…

Python實現GO鵝優化算法優化Catboost回歸模型項目實戰

說明&#xff1a;這是一個機器學習實戰項目&#xff08;附帶數據代碼文檔視頻講解&#xff09;&#xff0c;如需數據代碼文檔視頻講解可以直接到文章最后關注獲取。 1.項目背景 在當今的數據驅動時代&#xff0c;機器學習模型在各種應用中扮演著至關重要的角色。特別是在預測分…

如何在docker上部署前端nginx服務(VUE)

目錄結構 clean.sh docker stop rszWeb; docker rm rszWeb; start.sh docker run -d \ --name rszWeb \ -p 7084:80 \ -m 500m \ --privileged=true \ --restart=always \ -v /home/rsz/ui/conf/nginx.conf:/etc/nginx/nginx.conf \ -v /home/rsz/ui/logs:/meta/logs \ -v /…

可獄可囚的爬蟲系列課程 15:防盜鏈反爬蟲的處理

一、防盜鏈了解 防盜鏈是一種技術手段&#xff0c;主要用于防止其他網站通過直接鏈接的方式使用本網站的資源&#xff08;如圖片、文件等&#xff09;&#xff0c;從而節省帶寬和服務器資源。當其他網站嘗試直接鏈接到受保護的資源時&#xff0c;服務器會根據設置的規則判斷請求…

2020年藍橋杯Java B組第二場題目+部分個人解析

#A&#xff1a;門牌制作 624 解一&#xff1a; public static void main(String[] args) {int count0;for(int i1;i<2020;i) {int ni;while(n>0) {if(n%102) {count;}n/10;}}System.out.println(count);} 解二&#xff1a; public static void main(String[] args) {…

Hadoop架構詳解

Hadoop 是一個開源的分布式計算系統&#xff0c;用于存儲和處理大規模數據集。Hadoop 主要由HDFS&#xff08;Hadoop Distributed File System&#xff09;、MapReduce、Yarn&#xff08;Jobtracker&#xff0c;TaskTracker&#xff09;三大核心組件組成。其中HDFS是分布式文件…

DeepSeek在初創企業、教育和數字營銷領域應用思考

如今&#xff0c;像 DeepSeek 這樣的人工智能工具正在改變企業的運營方式&#xff0c;優化流程并顯著提高生產力。通過重復任務的自動化、大量數據的分析以及內容創建效率的提高&#xff0c;組織正在尋找新的競爭和卓越方式。本文介紹了 DeepSeek 如何用于提高三個關鍵領域的生…

day7作業

編寫一個如下場景&#xff1a; 有一個英雄Hero類&#xff0c;私有成員&#xff0c;攻擊&#xff08;Atx&#xff09;&#xff0c;防御&#xff08;Defense&#xff09;&#xff0c;速度&#xff08;Speed)&#xff0c;生命值&#xff08;Blood)&#xff0c;以及所有的set get 方…

阿里云ack的創建與實戰應用案例

阿里云ack的創建與應用案例 創建前開通ack相關服務&#xff1a;開始創建簡單的魔方游戲&#xff0c;熟悉sv與clb自動注冊創建部署一個nginx 服務示例&#xff1a;走不同域名訪問不同svc資源&#xff1a;為什么需要 Ingress &#xff1f;創建第一個域名的 Deployment和Service。…

青少年編程都有哪些比賽可以參加

Python小學生可參加的賽事&#xff1a; 電子學會青少年編程考級、中國計算機學會編程能力等級認證、藍橋杯、 信奧賽CSP-J/S初賽/NOIP(推薦C)、編程設計、信息素養、科技創新賽&#xff1b; 升學助力(科技特長生、大學)、企業、出國留學&#xff1b; python比賽&am…

MinIO在 Docker中修改登錄賬號和密碼

MinIO在 Docker中修改登錄賬號和密碼 隨著云計算和大數據技術的快速發展&#xff0c;對象存儲服務逐漸成為企業數據管理的重要組成部分。MinIO 作為一種高性能、分布式的對象存儲系統&#xff0c;因其簡單易用、高效可靠的特點而備受開發者青睞。然而&#xff0c;在實際應用中…

pycharm編寫ai大模型api調用程序及常見錯誤

這里寫目錄標題 一級目錄1. 訪問Django項目&#xff0c;python web url時&#xff0c;報錯2. 傳參報名&#xff0c;python web url時&#xff0c;報錯正確訪問結果&#xff1a; 二、購買價格 和 見錯誤碼 一級目錄 1. 訪問Django項目&#xff0c;python web url時&#xff0c;…

RISCV指令集解析

參考視頻&#xff1a;《RISC-V入門&進階教程》1-4-RV32I基本指令集&#xff08;1&#xff09;_嗶哩嗶哩_bilibili privilege是特權指令集&#xff0c;有點系統調用的感覺&#xff0c;要走內核態。unprivilege指令集有點像普通的函數調用。